当前位置:  编程技术>移动开发
本页文章导读:
    ▪透过手机发送短信的程序        通过手机发送短信的程序 最近几天研究通过数据线把手机和电脑连接起来,然后发送手机短信,看了点PDU编码的东西,那个PDU编码的东东害的我花费了两天时间没有发送出短信,而同事在.........
    ▪ 一些惯用的接口及sdk资源收集        一些常用的接口及sdk资源收集 新浪微博sdkhttp://open.weibo.com/wiki/SDKAndroid口袋微博案例http://open.weibo.com/wiki/Android%E5%8F%A3%E8%A2%8B%E5%BE%AE%E5%8D%9A%E6%A1%88%E4%BE%8B ......
    ▪ Widget中PendingIntent跟RemoteViews用法       Widget中PendingIntent和RemoteViews用法 PendingIntent是指把Intent包装了一层, 并且把PendingIntent放入一个新的进程. 通过触发事件去触发这个PendingIntent.创建PendingIntent方法.1. getActivity(Context context, int reques.........

[1]透过手机发送短信的程序
    来源: 互联网  发布时间: 2014-02-18
通过手机发送短信的程序
最近几天研究通过数据线把手机和电脑连接起来,然后发送手机短信,看了点PDU编码的东西,那个PDU编码的东东害的我花费了两天时间没有发送出短信,而同事在无意中看到其编码的规则,加上我的理解,做些记录。

首先,通过手机发送中文短信,必须采用PDU的编码方式发送短信,所以在先要发送AT指令,告诉手机,发的是PDU编码:(C#伪代码)
SerialPort port
command = AT+CMGF=0
port.Write(command + "\r");

其次,再告诉手机,你的整个PDU的编码长度是多少:
int cnt = 15 + (pdu.Length - 32) / 2;
command = AT+CMGS=cnt;
port.Write(command + "\r");
String pdu = getPDUMessage(Message,PhoneNo);
//23=15+8,15是 PDU的编码规约头,固定是15,后面的8是你传的汉字的长度,一个汉字两个字符,所以这里的8是我传了4个汉字,规约头的购成见下面的PDU编码方法,即PDU的常量值

private string getPDUMessage(string Sms_Text, string Dest_Number)
        {
            string pdu = ""; //开始合成 PDU 串
            pdu += "0011000D9168";
            //SMSC中心号码补F凑成偶数
            /*char[] tmpSmscNumber = ("13800100500" + "F").ToCharArray();
            for (int i = 0; i < tmpSmscNumber.Length; i += 2) //字符两两对调
            {
                pdu += tmpSmscNumber[i + 1].ToString();
                pdu += tmpSmscNumber[i].ToString();
            }*/这段代码原来是要加上短信服务中心的号码,加上后不能发短信了,所以得去掉
      
           
           char[] tmpDestNumber = (Dest_Number + "F").ToCharArray();//对方号码
            for (int i = 0; i < tmpDestNumber.Length; i += 2) //字符两两对调
            {
                pdu += tmpDestNumber[i + 1].ToString();
                pdu += tmpDestNumber[i].ToString();
            }
            pdu += "000800"; //08 表示采用 UCS2 编码
            //短信正文转为Unicode                                    
            byte[] tmpSmsText = Encoding.Unicode.GetBytes(Sms_Text);
            pdu += tmpSmsText.Length.ToString("X2"); //正文内容长度
            for (int i = 0; i < tmpSmsText.Length; i += 2) //高低字节对调
            {
                pdu += tmpSmsText[i + 1].ToString("X2");//("X2")转为16进制
                pdu += tmpSmsText[i].ToString("X2");
            } //PDU串 完成
            return pdu;
        }

最后,发送PDU的短信
command = pdu + "\x01a";
port.Write(command);

我开始一直发送不成功的原因就是PDU的长度和实际长度不一致造成的
注意,里面的command是字符串,要用引号引起来

    
[2] 一些惯用的接口及sdk资源收集
    来源: 互联网  发布时间: 2014-02-18
一些常用的接口及sdk资源收集
新浪微博sdk
http://open.weibo.com/wiki/SDK
Android口袋微博案例
http://open.weibo.com/wiki/Android%E5%8F%A3%E8%A2%8B%E5%BE%AE%E5%8D%9A%E6%A1%88%E4%BE%8B

    
[3] Widget中PendingIntent跟RemoteViews用法
    来源: 互联网  发布时间: 2014-02-18
Widget中PendingIntent和RemoteViews用法
PendingIntent是指把Intent包装了一层, 并且把PendingIntent放入一个新的进程. 通过触发事件去触发这个PendingIntent.

创建PendingIntent方法.
1. getActivity(Context context, int requestCode, Intent intent, int flags)

2. getBroadcast(Context context, int requestCode, Intent intent, int flags)

3. getService(Context context, int requestCode, Intent intent, int flags)

例子:
在/res/xml中新建一个example_appwidget.xml
<?xml version="1.0" encoding="utf-8"?>
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
	android:minWidth="294dp" android:minHeight="72dp"
	android:updatePeriodMillis="86400000" android:initialLayout="@layout/example_appwidget_info">

</appwidget-provider>


在/res/layout中新建一个example_widget.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
	android:orientation="vertical" android:layout_width="match_parent"
	android:layout_height="match_parent">
	<TextView android:text="firstWidgetText" android:background="#000000"
		android:id="@+id/widgetTextId" android:layout_width="fill_parent"
		android:layout_height="wrap_content"></TextView>
	<Button android:layout_width="match_parent" android:id="@+id/button1" android:text="Button" android:layout_height="wrap_content"></Button>

</LinearLayout>


main.xml的内容不变

ExampleAppWidgetProvider.java内容
package com.cn;

import android.app.PendingIntent;
import android.appwidget.AppWidgetManager;
import android.appwidget.AppWidgetProvider;
import android.content.Context;
import android.content.Intent;
import android.widget.RemoteViews;

public class ExampleAppWidgetProvider extends AppWidgetProvider {

	@Override
	public void onDeleted(Context context, int[] appWidgetIds) {
		System.out.println("onDeleted");
		super.onDeleted(context, appWidgetIds);
	}

	@Override
	public void onDisabled(Context context) {
		System.out.println("onDisabled");
		super.onDisabled(context);
	}

	@Override
	public void onEnabled(Context context) {
		System.out.println("onEnabled");
		super.onEnabled(context);
	}

	@Override
	public void onReceive(Context context, Intent intent) {
		System.out.println("onReceive");
		super.onReceive(context, intent);
	}

	@Override
	public void onUpdate(Context context, AppWidgetManager appWidgetManager,
			int[] appWidgetIds) {
		System.out.println("onUpdate");
		for (int i = 0; i < appWidgetIds.length; i++) {
			System.out.println(appWidgetIds[i]);
			//创建一个intent对象
			Intent intent = new Intent(context,TargetActivity.class);
			//创建一个PendingIntent
			PendingIntent pending = PendingIntent.getActivity(context, 0, intent, 0);
			RemoteViews remoteViews = new RemoteViews(context.getPackageName(),R.layout.example_widget);
			//第一个参数用来指定绑定事件的id
			//第二个参数指定事件发生时, 哪个pendingIntent会被执行
			remoteViews.setOnClickPendingIntent(R.id.button1, pending);
			//第一个参数是更新哪个appwidget的id
			//第二个是传remoteView
			appWidgetManager.updateAppWidget(appWidgetIds[i], remoteViews);
		}
		super.onUpdate(context, appWidgetManager, appWidgetIds);
	}

}


AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.cn"
      android:versionCode="1"
      android:versionName="1.0">
    <uses-sdk android:minSdkVersion="10" />

    <application android:icon="@drawable/icon" android:label="@string/app_name">
        <activity android:name=".Appwidget2Activity"
                  android:label="@string/app_name">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
		<receiver android:name="ExampleAppWidgetProvider">
        	<!-- 指定广播接收 -->
            <intent-filter>
                <action android:name="android.appwidget.action.APPWIDGET_UPDATE"></action>
            </intent-filter>
            <!-- appwidget的源文件 -->
            <meta-data android:name="android.appwidget.provider" android:resource="@xml/example_appwidget_info"></meta-data>
        </receiver>
		<activity android:name="TargetActivity"></activity>
    </application>
</manifest>



TargetActivity.java内容
package com.cn;

import android.app.Activity;
import android.os.Bundle;

public class TargetActivity extends Activity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
	}

}

    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android按钮单击事件的四种常用写法总结
▪Android消息处理机制Looper和Handler详解
▪Android实现Back功能代码片段总结
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
WEB前端 iis7站长之家
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
▪Android提高之手游转电视游戏的模拟操控
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3