基于rexsee扩展的rexseeSMS,通过JS实现短信读取相关功能,如:
【函数】 JsonArray getContentUris()
【说明】 读取短信相关的所有数据库表的Uri地址。
【返回】 Json对象字符串,可以用eval('('+json+')')转换为JavaScript对象。
【参数】 无
【示例】
【函数】 JsonObjectArray get(int number)
【说明】 读取若干条短信。
【返回】 Json对象数组字符串,可以用eval('('+json+')')转换为JavaScript对象数组,注意,其中body字段是escape过的,使用前需要unescape。
【参数】 number:要读取的短信条数。
【示例】
其它还有:
- getUnread(int number):读取若干条未读短信;
- getRead(int number):读取若干条已读短信;
- getInbox(int number):从收件箱读取若干条短信;
- getSent(int number):读取若干条已发短信;
- getByThread(int threadID):读取会话中所有短信;
- getThreads(int number):读取若干条会话;
- getData(String selection, int number):根据条件读取若干条短信。
详细源码:
/* * Copyright (C) 2011 The Rexsee Open Source Project * * Licensed under the Rexsee License, Version 1.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.rexsee.com/CN/legal/license.html * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package rexsee.communication; import rexsee.core.browser.JavascriptInterface; import rexsee.core.browser.RexseeBrowser; import rexsee.core.utilities.Escape; import android.content.ContentResolver; import android.content.Context; import android.database.Cursor; import android.net.Uri; public class RexseeSMS implements JavascriptInterface { private static final String INTERFACE_NAME = "SMS"; @Override public String getInterfaceName() { return mBrowser.application.resources.prefix + INTERFACE_NAME; } @Override public JavascriptInterface getInheritInterface(RexseeBrowser childBrowser) { return this; } @Override public JavascriptInterface getNewInterface(RexseeBrowser childBrowser) { return new RexseeSMS(childBrowser); } public static final String CONTENT_URI_SMS = "content://sms"; public static final String CONTENT_URI_SMS_INBOX = "content://sms/inbox"; public static final String CONTENT_URI_SMS_SENT = "content://sms/sent"; public static final String CONTENT_URI_SMS_CONVERSATIONS = "content://sms/conversations"; public static String[] SMS_COLUMNS = new String[]{ "_id", //0 "thread_id", //1 "address", //2 "person", //3 "date", //4 "body", //5 "read", //6; 0:not read 1:read; default is 0 "type", //7; 0:all 1:inBox 2:sent 3:draft 4:outBox 5:failed 6:queued "service_center" //8 }; public static String[] THREAD_COLUMNS = new String[]{ "thread_id", "msg_count", "snippet", }; private final Context mContext; private final RexseeBrowser mBrowser; public RexseeSMS(RexseeBrowser browser) { mBrowser = browser; mContext = browser.getContext(); } //JavaScript Interface public String getContentUris() { String rtn = "{"; rtn += "\"sms\":\"" + CONTENT_URI_SMS + "\""; rtn += ",\"inbox\":\"" + CONTENT_URI_SMS_INBOX + "\""; rtn += ",\"sent\":\"" + CONTENT_URI_SMS_SENT + "\""; rtn += ",\"conversations\":\"" + CONTENT_URI_SMS_CONVERSATIONS + "\""; rtn += "}"; return rtn; } public String get(int number) { return getData(null, number); } public String getUnread(int number) { return getData("type=1 AND read=0", number); } public String getRead(int number) { return getData("type=1 AND read=1", number); } public String getInbox(int number) { return getData("type=1", number); } public String getSent(int number) { return getData("type=2", number); } public String getByThread(int thread) { return getData("thread_id=" + thread, 0); } public String getData(String selection, int number) { Cursor cursor = null; ContentResolver contentResolver = mContext.getContentResolver(); try { if (number > 0) { cursor = contentResolver.query(Uri.parse(CONTENT_URI_SMS), SMS_COLUMNS, selection, null, "date desc limit " + number); } else { cursor = contentResolver.query(Uri.parse(CONTENT_URI_SMS), SMS_COLUMNS, selection, null, "date desc"); } if (cursor == null || cursor.getCount() == 0) return "[]"; String rtn = ""; for (int i = 0; i < cursor.getCount(); i++) { cursor.moveToPosition(i); if (i > 0) rtn += ","; rtn += "{"; rtn += "\"_id\":" + cursor.getString(0); rtn += ",\"thread_id\":" + cursor.getString(1); rtn += ",\"address\":\"" + cursor.getString(2) + "\""; rtn += ",\"person\":\"" + ((cursor.getString(3) == null) ? "" : cursor.getString(3)) + "\""; rtn += ",\"date\":" + cursor.getString(4); rtn += ",\"body\":\"" + Escape.escape(cursor.getString(5)) + "\""; rtn += ",\"read\":" + ((cursor.getInt(6) == 1) ? "true" : "false"); rtn += ",\"type\":" + cursor.getString(7); rtn += ",\"service_center\":" + cursor.getString(8); rtn += "}"; } return "[" + rtn + "]"; } catch (Exception e) { mBrowser.exception(getInterfaceName(), e); return "[]"; } } public String getThreads(int number) { Cursor cursor = null; ContentResolver contentResolver = mContext.getContentResolver(); try { if (number > 0) { cursor = contentResolver.query(Uri.parse(CONTENT_URI_SMS_CONVERSATIONS), THREAD_COLUMNS, null, null, "thread_id desc limit " + number); } else { cursor = contentResolver.query(Uri.parse(CONTENT_URI_SMS_CONVERSATIONS), THREAD_COLUMNS, null, null, "thread_id desc"); } if (cursor == null || cursor.getCount() == 0) return "[]"; String rtn = ""; for (int i = 0; i < cursor.getCount(); i++) { cursor.moveToPosition(i); if (i > 0) rtn += ","; rtn += "{"; rtn += "\"thread_id\":" + cursor.getString(0); rtn += ",\"msg_count\":" + cursor.getString(1); rtn += ",\"snippet\":\"" + Escape.escape(cursor.getString(2)) + "\""; rtn += "}"; } return "[" + rtn + "]"; } catch (Exception e) { mBrowser.exception(getInterfaceName(), e); return "[]"; } } }
二维码网址的应用 引言
现在智能机比较普遍,比较便宜的如联想的,只要八九百就可以搞个Android智能机。用智能机来上网是很多人用来打发时间的手段,比如上下班坐地铁的时候。比较麻烦的事,就是在手机上输入网址,费劲。如果你知道二维码的话,就比较轻松。用手机扫描二维码网址,就可以实现轻松上网,免去了输入网址的麻烦。不信试一下下面的二维码网址。在 Android 手机上,需要下载 二维码 应用程序。
二维码的类别
二维码又叫做二维条码,是指在一维条码的基础上扩展出另一维具有可读性的条码,使用黑白矩形图案表示二进制数据,被设备扫描后可获取其中所包含的信息。二维码的主要种类有:PDF417码 、QR码、汉信码、颜色条码等等。在线二维码生成器生成的就是QR码。
二维码的定位点
二维码通常有三个定位点,这三个定位点提供读码机辨识。因为有这些定位点,所以二维码不管是从何种方向读取都可以被辨识。
二维码的特性
二维码比一维条码记载数据量更多。而且可以记载更复杂的数据,比如图片、网络链接等。
二维码的应用
二维码跟以往的一维码一样,在商业活动中应用广泛,特别是在高科技行业、储存运输业、批发零售业等需要对物品进行廉价快捷的标示信息的行业用途广泛。 在日本等一些国家地区,像QR码一样容易生成及读取的条形码已经成为生活中快捷便利的信息交流方式。 在一些国家,已经采用PDF417码作为身份识别的标签,并直接印制在身份识别的证件上,以便快速读取。在台湾则被应用于综合所得税的报税方式之一,将报税资料印在二维码内,节省税务机关输入资料的时间;台湾高铁、中国大陆的火车票票面上也均印有防伪二维码。
在2012年春节期间,中国大陆的一家线上支付平台支付宝实现了通过二维码进行银行卡转账和送红包的功能,允许用户在支付宝平台在线生产、制作“电子红包”二维码,其包含了转账金额、收款人和祝福语等信息,并通过互联网发送至收款人,收款人使用相关设备扫描二维码后,账款就可以成功地转入其银行账户中。
具体到我们自己的网站,该怎么用二维码网址图片?如果网站也提供了WAP版或者HTML5版,那么可以有如下使用方式:
- 在网站上放置一个二维码网址图片,方便支持扫描二维码网址的手机使用;
- 在海报、广告或DM杂志的合适位置,放置这个二维码网址图片;
- 在营销邮件中放入二维码网址图片,让有兴趣的收件人方便的扫描;
- ...(欢迎有这方面的经验的童鞋补充,谢谢!)
1.高密度编码,信息容量大:
可容纳多达1850个大写字母或2710个数字或1108个字节,或500多个汉字,比普通条码信息容量约高几十倍。
2.编码范围广:
该条码可以把图片、声音、文字、签字、指纹等可以数字化的信息进行编码,用条码表示出来;可以表示多种语言文字;可表示图像数据。
3.容错能力强,具有纠错功能:
这使得二维条码因穿孔、污损等引起局部损坏时,照样可以正确得到识读,损毁面积达50%仍可恢复信息。
4.译码可靠性高:
它比普通条码译码错误率百万分之二要低得多,误码率不超过千万分之一。
5.可引入加密措施:
保密性、防伪性好。
6.成本低,易制作,持久耐用。
好用的在线二维码生成工具
- 在线二维码生成器
http://cli.im/
特点:简单易用,能自动识别输入的网址,提示“你输入了一个网址,如果填写标题就可以生成二维码书签。”
不足之处:不能通过网址共享出去,只能自行保存成png图片。
PS:上面的二维码介绍资料就来自该网站
http://cli.im/what-is-qrcode.html
- MAYA CODE 二维码自助区
http://www.mayacode.com/
也很不错哦。
- 二维工坊
http://www.2weima.com/
评论:这个网站不错,不仅有二维码生成工具(包括通用二维码、彩色二维码、艺术化二维码),还有很多二维码的资讯信息,关注二维码的可以上去看看。
怎么使用二维码推广你的app
http://www.2weima.com/site/news/3
利用二维码进行市场推广的十大新玩法
http://www.2weima.com/site/news/2
令人拍案叫绝的15个二维码
http://www.2weima.com/site/news/6
下面这个好看的二维码就来自该网站。
转自:http://blog.buaa.us/?p=48
这问题出现实在让人D疼的不行,装过4.2的卸载了再安装4.3,苹果会删除掉以前的Develop文件夹,导致系统找不到位于Develop文件夹下的众多命令 ,如果找到了原因,解决的办法也就很简单了,先去找最新的Xcode.app下各种命令的位置,结果是在
- /Applications/Xcode.app/Contents/Developer/usr/bin
下面,然后修改$PATH的值:
- vim ~/.bash_profile
增加上面的路径到PATH里面:
- export PATH=.:/opt/local/bin:/opt/local/sbin:/Applications/Xcode.app/ Contents/Developer/usr/bin:$PATH
保存退出后
- source ~/.bash_profile
这时候再打xcodebuild命令,就有反应了
- xcodebuild -target “xxxxxx” -configuration Debug -sdk iphoneos
一大通log之后,久违的东西出现了!
- ** BUILD SUCCEEDED **