Wince及mobile常用代码(续)
一、怎样将已安装好的应用程序卸载:
用unload.exe,
szUninstallBuf这个参数必须和注册表 HLM\SOFTWARE\APPS\下的对应应用的名称一致。
有个前提,使用这个必须是在cab中没有指定 nouninstall这个参数
PROCESS_INFORMATION stProgressInfo;
if ( CreateProcess(_T("\\Windows\\unload.exe"), szUninstallBuf, NULL, NULL, NULL, 0, NULL, NULL, NULL, &stProgressInfo) )
二、屏蔽talk键(打电话的那个键):向窗口发送SHCMBM_OVERRIDEKEY消息,在WM_HOTKEY中进行处理。
参考SDK自带的Sample,位于“Windows Mobile 6 SDK\Samples\Common\CPP\Win32\FullScreen”目录。该例子演示了如何在Windows Mobile上隐藏taskbar和softkey,进行全屏显示。其中,退出全屏的功能,采用softkey按钮来实现。而具体的方式,就是向窗口发送SHCMBM_OVERRIDEKEY消息,在WM_HOTKEY中,加入用户自己的应用。以该工程为例,我们进行修改,加入“按Talk按键退出全屏”这个功能,而不弹出拨号界面。
1.在SetSoftkeyBarForFullScreen函数中,加入消息发送函数:
// Override/Undo softkeys for key press notifications, so we can
// display taskbar & softkeys on SK1/SK2 press in full screen.
DWORD dwBits;
dwBits = bFullScreen
? SHMBOF_NODEFAULT | SHMBOF_NOTIFY
: 0;
SendMessage(hwndSoftKeyBar,
SHCMBM_OVERRIDEKEY,
VK_TSOFT1,
MAKELPARAM(SHMBOF_NODEFAULT | SHMBOF_NOTIFY, dwBits));
SendMessage(hwndSoftKeyBar,
SHCMBM_OVERRIDEKEY,
VK_TSOFT2,
MAKELPARAM(SHMBOF_NODEFAULT | SHMBOF_NOTIFY, dwBits));
//加入的消息发送函数
SendMessage(hwndSoftKeyBar,
SHCMBM_OVERRIDEKEY,
VK_TTALK,
MAKELPARAM(SHMBOF_NODEFAULT | SHMBOF_NOTIFY, dwBits));
2.在CALLBACK DialogProc(…)函数的WM_HOTKEY中,加入VK_TTALK键的处理:
caseVK_TTALK:
{
// if we are in full screen mode we want to exit
// when the user presses a softkey.
if(g_bFullScreen)
{
SendMessage(GetDlgItem(hWnd,IDC_EDIT), WM_SETTEXT, 0, (LPARAM)L"[TALKkey] Exiting Full Screen");
FullScreen(hWnd, FALSE);
}
}
break;
有关参考如下:
WM_HOTKEY:http://msdn.microsoft.com/en-us/library/aa453868.aspx
SHCMBM_OVERRIDEKEY:http://msdn.microsoft.com/en-us/library/aa454997.aspx
三、Windows Mobile上的无线网络接入点扫描:codeproject上有个Wifi AP扫描程序,称为:Wifi scanner + custom MFC controls。用它能够扫描当前的无线环境,发现周围的AP接入点,显示他们的名字、MAC地址、信号强度(RSSI)、Wifi信道以及是否需要密码等信息。
源码的运行设备是Pocket PC 2003se,要运行在window mobile平台,要在编译选项中Configuration Manger中选中wm设备,Active solution platform
Download demo project - 97.6 Kb
Download source - 90.8 Kb
四、短信相关的AT指令:
AT+CMGC:发出一条短消息
AT+CMGD:删除SIM卡内存的短消息
AT+CMGF:选择短消息信息格式:0-PDU;1-文本
AT+CMGL:列出SIM卡中的短消息PDU/text: 0/"REC UNREAD"-未读,1/"REC READ"-已读,2/"STO UNSENT"-待发,3/"STO SENT"-已发,
4/"ALL"-全部的
AT+CMGR:读短消息
AT+CMGS:发送短消息
AT+CMGW :向SIM内存中写入待发的短消息
AT+CMSS:从SIM卡内存中发送短消息
AT+CNMI:显示新收到的短消息
AT+CPMS:选择短消息内存
AT+CSCA:短消息中心地址
AT+CSCB :选择蜂窝广播消息
AT+CSMP:设置短消息文本模式参数
AT+CSMS:选择短消息服务
相关代码:
初始化短信模式设置的时候,可以使用:
//set AT+CMGF=1+回车换行
m_serialPort2.Write(new char[] { 'A', 'T', '+', 'C', 'M', 'G', 'F', '=', '1' }, 0, 9);
m_serialPort2.Write(new byte[] { 0x0D }, 0, 1);
m_serialPort2.Write(new byte[] { 0x0A }, 0, 1);
短信内容发送完毕必须以十六进制数0x1A结束,例如,发送短信时,先发送对方号码,然后发送数据:
//发送text中输入的对方手机号码
stATCommand = "AT+CMGS=+86" + textBoxPhoneNumber.Text;
btATCommand = stATCommand.ToCharArray();
m_serialPort2.Write(btATCommand, 0, 22);
m_serialPort2.Write(new byte[] { 0x0D }, 0, 1);
m_serialPort2.Write(new byte[] { 0x0A }, 0, 1);
Thread.Sleep(15);
m_serialPort2.Write(new char[] { 'H', 'e', 'l', 'l', 'o'}, 0, 5);
//set SMS end symbol
m_serialPort2.Write(new byte[] { 0x1A }, 0, 1);
//发送text中输入的对方手机号码
stATCommand = "AT+CMGS=+86" + textBoxPhoneNumber.Text;
btATCommand = stATCommand.ToCharArray();
m_serialPort2.Write(btATCommand, 0, 22);
m_serialPort2.Write(new byte[] { 0x0D }, 0, 1);
m_serialPort2.Write(new byte[] { 0x0A }, 0, 1);
Thread.Sleep(15);
m_serialPort2.Write(new char[] { 'H', 'e', 'l', 'l', 'o'}, 0, 5);
//set SMS end symbol
m_serialPort2.Write(new byte[] { 0x1A }, 0, 1);
五、怎样通过CMPP短信网关下发wap push ,相对于下发普通短信,有两个地方不同。
1、CMPP_SUBMIT消息包的部分参数值改变。具体是:
Msg_Fmt = 4(表示消息内容是二进制),
TP_pid = 0;
TP_udhi = 1;
2、字段Msg_Content的内容是二进制数字,有特定的组合方式。格式解析起来,就是所谓的
“压缩后的XML“,即WBXML,一共有7个部分,把每个部分的二进制码按顺序组合起来填入
Msg_Content字段,当做普通短信下发即可。代码大概如下:
char szWapPushHeader1[12] = {0x0B, 0x05, 0x04, 0x0B, 0x84, 0x23, 0xF0, 0x00, 0x03,
0x03, 0x01, 0x01};
char szWapPushHeader2[9] = {0x29, 0x06, 0x06, 0x03, 0xAE, 0x81, 0xEA, 0x8D, 0xCA};
char szWapPushIndicator[8] = {0x02, 0x05, 0x6A, 0x00, 0x45, 0xC6,0x0C, 0x03};
char szWapPushDisplayTextHeader[3] = {0x00, 0x01, 0x03};
char szEndOfWapPush[3] = {0x00, 0x01, 0x01};
//以上数字串是什么意思,估计有几个说明可以参考下, 又是前人经验:
//0B WAP PUSH头部的总长度
//05040B8423F0表示接下来是一个WAP PUSH
//00 表示是Concatenated Short Messages
//03 长度
//03 reference number
//01 表示分成1个短信发送
//01 当前包的序号
//这个并不不影响功能的样子。好象只需要知道分几条短信和
//序号发就可以了。以上每个部分,也有其他可以通过测试的不同的串值,目前只测了这种
//常见的值。
//以下两个字串就是需要自己填写的了:
//szWapPushUrl:wap push的目的链接,费尽心机不就是想把这个发出去嘛。要求是"去除了
//http://前缀的UTF8编码的Url地址"的二进制编码。现在是小测试,直接写上值吧,否则应
//该是经过编码转化的。以下url内容是"wap.sina.com.cn"
char szWapPushUrl[12] = {0x77,0x61,0x70,0x2E,0x73,0x69,0x6e,0x61,0x2e,0x63,0x6f,0x6d};
//这个,就是想在手机上显示的关于这个URL的文字说明了,在我的手机上显示成该wap push
//的标题.也同样是"UTF8编码的二进制"内容是"好好学习"
char szMsg[12] = {0xE5,0xA5,0xBD,0xE5,0xA5,0xBD,0xE5,0xAD,0xA6,0xE4,0xB9,0xA0};
具体的实现代码如下:
char szHex[1024];
int iUrllen,iMsgLen,iLen;
iUrllen = 12;
iMsgLen = 12;
memset(szHex, 0, sizeof(szHex));
iLen = 0;
memcpy(szHex, szWapPushHeader1, 12);
iLen += 12;
memcpy(szHex+iLen, szWapPushHeader2, 9);
iLen += 9;
memcpy(szHex+iLen, szWapPushIndicator, 8);
iLen += 8;
memcpy(szHex+iLen, szWapPushUrl, iUrllen);
iLen += iUrllen;
memcpy(szHex+iLen, szWapPushDisplayTextHeader, 3);
iLen += 3;
memcpy(szHex+iLen, szMsg, iMsgLen);
iLen += iMsgLen;
memcpy(szHex+iLen, szEndOfWapPush, 3);
iLen += 3;
Msg_Length = iLen;
memcpy((char*)Msg_Content, szHex, Msg_Length);
//把Msg_Content当普通短信下发就可以了。对于push很多地方是被运营商给屏蔽了。
六、Cookie文件格式,默认位置:默认位置是Windows\Profiles\Guest\Cookies,持久性cookie,有一个截止日期,都存储在HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders的注册表项中指定的位置;
如果没有到期日,会话cookie都存储在内存中,并且只提供给创建它们的进程使用。
所以,要设置一个多个进程都可以使用的cookie,必须设置好到期日。
格式如下:
cnt_uid_www
fa565c5abe27b0eb1f0497
csdn.net/
1536
560450176
29956594
2009325664
29943116
*
其中
第1行为Cookie名称;
第2行是Cookie的值;
第3行是Cookie所属站点的地址;
第4行是个标记值;
第5行为超时时间的低位(Cardinal/DWORD);
第6行为超时时间的高位;
第7行为创建时间的低位;
第8行为创建时间的高位;
第9行固定为 * ,表示一节的结束。
一个文件可能包含有多个节,按上面的格式循环即可。
也可以用程序来写cookie,当打开相关网页时,网页可自动识别,虽然这样的实际应用并不是很常见。
InternetSetCookie(L"csdn.net/", L"cnt_uid_www", L"fa565c5abe27b0eb1f0497;expires=Sat,10-Jul-2010 00:00:00 GMT");
如上,“expires=Sat,10-Jul-2010 00:00:00 GMT”指定了cookie的有效期限。
注册表位置:HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer \Shell Folders,下面的
Cache、Cookies、History三个子键路径中的“Windows\”全部换成“Storage Card\”即可。系统会自动在SD卡上创建自己的路径。
再将Windows目录下的profiles整个文件夹删掉,文件目录已经建立到SD卡上的 \Storage Card\profiles了,