结合自己4,5月份开发手机视频监控系统经历, 来对那段时间的Windows Mobile开发进行总结一下. 说起Windows Mobile开发这事自己几乎是从零开始起步, 原先主要从事J2EE/Asp.Net下的Web应用开发, 从来没有接触过移动应用开发方面; 说零起步, 夸张点了, 好在至少对自己决定采用的开发工具Vs 2005还是有相当了解的, 从大学开始就用它开发Asp.Net/WinForm项目, 那就是说在开发工具上没有什么大问题了, 一个好的工具, 可以极大地提高我们的开发效率; 以及加上去年进入这家主要从事安防监控方面的公司, 虽然安排主要还是做Web开发, 但供Web监控使用的视频监控ActiveX控件也需由我来实现; 毕业之后一直使用的不是C#就是Java, 在大学里学得那点C++, 早就还给老师了. 针对自己这点可怜的C++开发基础, 对即将从事的手机上应用, 明显不足. 后来我花了2周时间去巩固C++, 主要学习Socket网络通信, 多线程处理等跟项目关联密切内容(主要是在C++博客上看别人的博文, 前几天把那段时间收藏的C++开发相关文章整理了一下, 见博文C++开发文章收藏); 如果你打算学习Win32来开发WM应用的话, Programming.Windows与Programming WinCE NET 3rd这2本书不错, 当然入门对照着MSDN看微软SDK带的例子学习更加是一个好途径, 基本上开发常见功能都有介绍, 如菜单,对话框全屏,TreeView控件等, 值得用心去体会. 如果是C#的话也类似, 边看书,边看文章,边看WebCast,基础要尽量打扎实。该项目平台是vs 2005 + WM 5.0 SDK(Pocket PC), 开发语言采用Win32(直接是C++ + SDK API), 因为公司就安排我一个人做手机客户端开发, 提供视频流的服务端由另外人来完成.
希望能够与有跟我有着类似经历或者有志于WM开发的XDJM多多交流, 下面我将从开发环境搭建, 模拟器使用, 具体应用开发等方面来加以总结. 我的弯路大家可以
避免, 我的经验大家可以分享。
手机视频监控系统
先允许我简单介绍一下什么是手机视频监控系统? 手机视频监控作为手机上多媒体/流媒体应用其中一种, 特别是在当前国内3大电信公司大力推行3G网络背景下, 其
在音视频应用方面占了较大比重, 也是3G下的一大亮点. 手机视频监控系统是通过用户的手机随时随地来观看远程监控点的视频。并允许用户进行远程云台控制, 本地
录像存储与回放, 监控场地发生意外情况时,通过活动视频向手机报警或短信, 彩信截图通知.
实际可应用的范围:
- 商业店铺:商场店铺的监控,收银、货架、出入口监控
- 居民住宅:室内远程图象报警、小区 / 大楼安全防范、物业的无人监控
- 教育行业:幼儿园、小学校的教学评估,家长远程监控
- 旅游行业:宾馆饭店的楼层管理、重点文物及景点的保护
更多内容可以看我前几个月的文章家庭视频监控, 手机视频监控系统, 手机视频监控系统需求, 手机流媒体技术简介, 手机视频监控系统小结.
Windows Mobile开发环境搭建
01. 开发环境搭建
开发环境搭建对一个初学者来说是一件很头疼麻烦的事情, 好在在DevDiv论坛上看到了一个讲述环境搭建与快速入门的视频教程与相关介绍帖子, 很值得一看! 另外一
个帖子Windows Mobile开发环境搭建也不错, 后来网友alalmn贡献了一份C++开发Mobile(手机系统)开发系列视频教程.
02. VS2005/VS 2008创建智能设备项目失败的解决方法
当初微软发布IE8的时候, 下载安装看看, 谁知道搞得VS 2005弹出一个窗口提示网页脚本错误, 创建智能设备项目失败. 好像IE7下也有这个问题, 我是立马把IE8干掉
了, 后来在网上发现别人找到了解决方法, 可以看这里. 更多开发过程中会碰到的疑难杂症, 希望我整理的Windows Mobile 开发系列文章收藏 - 疑难杂症对你有帮助.
03. 调试问题
在启动模拟器调试时候提示DLL无法加载,找不到指定的模块,以及遇调试中"系统找不到指定的路径"的问题, 应该怎么解决呢? 这类问题一般是由程序所需的DLL没有跟应用程序一起部署到手机上. 可以看看这2个帖子, 求助,各位高人,DLL无法加载,找不到指定的模块,怎么解决啊!快崩溃了~ , 再遇调试中"系统找不到指定的路径"的问题(再解决) .
模拟器
04. 模拟器部署程序不成功, 无法启动程序
模拟器部署程序不成功,不外乎3个原因, 1跟问题3类似缺少dll, 2上次运行程序没有正常退出, 还在运行, 可以从开始-->设置-->系统-->内存下检查有没有相关进程在运行, 3共享冲突且文件无法删除. 开发时候, 不时模拟器上出一些怪异现象, 我几次发现调试socket时候, 程序死活连不上服务器, 程序出现错误异常报告, 不知道何原因. 发现模拟器问题。可以采用如下步骤:
软重启,如果启动后无效进入下一步(选择模拟器菜单Soft Reset一般情况下上述问题都可以在这里得到解决, 平时保存模拟器状态前先把手机上的网络链接断开)
硬重启,如果还是无效进入下一步
卸载images,再次安装。
05. 模拟器上网
最简单方式是通过ActiveSync来上网, 另外一种比较复杂需要安装一个Microsoft Virtual PC通过PC网卡上网, 具体可以看[原创]模拟器上网的两种方法, 有一步步操作截图说明, 很直观清晰, 堪称经典之著.
06. 模拟器上中文显示
Vs 2005默认安装是英文版的模拟器, 在其上面, 中文不是显示成□或者就是?, 甚至就是空白, 在界面上啥都没有显示出来; 这个问题你可以安装中文版的模拟器来解决, WM5安装Windows Mobile 5.0 Emulator Images for Pocket PC - CHS.msi, 如果你是采用WM6开发的话安装Windows Mobile 6 Professional Images (CHS).msi, 至于相关模拟器下载可以参考文章Windows Mobile 开发系列文章收藏 - Device Emulator.
UI等具体实现
07. 全屏窗体实现
在实现全屏窗体时候经常会碰到如何隐藏mobile默认最下方的bar条, 输入法又突然冒出来; 实际上要实现全屏, 一般情况下采用SHFullScreen + MoveWindow +
WM_SETTINGCHANGE, 如果你要考虑一些更加多的细节, 下面这个帖子有可能对你有帮助, 关于Mobile的全屏实现的一点心得. 值得一提的是在网上同时看到1篇
文章, 可以说是讲述相反问题, 八股文的”实现真正的非全屏窗口和自定义消息对话框”很不错.
08. 如何去掉窗体上的关闭按钮?
SHDoneButton(hWnd,SHDB_HIDE);
SetWindowLong(hWnd,GWL_STYLE,WS_NONAVDONEBUTTON );
同时进行一下基础知识扫盲, PPC上窗体的关闭与最小化, 图来自黎波老师的博客文章. 在默认情况下,我们新建的窗体运行时屏幕右上角显示一个×按钮,
按照我们使用 Windows 的习惯,应该是用来关闭窗体。其实不是,它只是最小化窗体,并没有关闭。如果这个窗体是一个应用程序的主窗体,那么该程序并
没有退出,而是隐藏了。可以通过重新运行该程序的 exe 文件来恢复显示程序的运行界面或者到运行程序列表中进行激活显示。
09. 关于SIP开关后对话框的显示问题
也就是怎样实现软键盘打开, 对话框自动适应? 我们在开发过程中也会碰到, 如果对窗体中控件位置计算不正确, 会出现当输入法打开时把窗体上的编辑框给档住了,怎样实现输入法打开对话框自动上移? 可以响应WM_SETTINGCHANGE消息,通过SHSipInfo函数去得到输入法面板参数和桌面可视区域参数,然后配置你的对话框。
SIPINFO si = {0};
si.cbSize = sizeof(si);
SHSipInfo(SPI_GETSIPINFO, 0, &si, 0);
BOOL bShow = si.fdwFlags&SIPF_ON; // 如果bShow为TRUE,则软键盘显示,否则隐藏;使用si.rcSipRect和si.rcVisibleDesktop来实现你的需求。
10. WM手机默认中文编码是什么?
默认编码是Unicode, 所有的WM手机都是UNICODE的, 且SP平台和PPC都一样! 很多跟我一样刚接触WM开发的人都会碰到一个问题, 为什么同样的代码在VC6开发
的应用程序中没有问题, 但把相关代码复制到Windows Mobile上运行就出现如此多的编译错误, 如error C2664: 'CWnd::MessageBoxW' : cannot convert
parameter 1 from 'char [100]' to 'LPCTSTR'. 都是没有考虑到这一点(编码问题), 需要使用提供的字符串相关的API与函数加以处理. 字符串处理函数可以看这篇
下面简单介绍Unicode C-Runtime 转换函数
wchar_t *wcstr, // Output string.
const char *mbstr, // Input string.
size_t count ); // Character count
char *mbstr, // Output string.
const wchar_t *wcstr, // Input string.
size_t count ); // Character count
MultiByteToWideChar与WideCharToMultiByte
char str[256] = {(char)0xE4,(char)0xBD,(char)0xA0,(char)0xE5,(char)0xA5 ,(char)0xBD,(char)0x61,(char)0x62,(char)0x63,(char)0}; //一段UTF-8编码
WCHAR* strA;
int i = MultiByteToWideChar(CP_UTF8, 0, (char*)str, -1, NULL, 0);
strA = new WCHAR[i];
MultiByteToWideChar(CP_UTF8, 0, (char *)str, -1, strA, i);
i = WideCharToMultiByte(CP_ACP, 0, strA, -1, NULL, 0, NULL, NULL);
char *strB=new char[i];
WideCharToMultiByte(CP_ACP, 0, strA, -1, strB, i, NULL, NULL);
//strB即为所求
//AfxMessageBox(strB);
delete []strA;
delete []strB;
11. 在Windows Mobile下使用XML
XML当前被大量使用于应用程序配置, 存储少量数据以及Web Services等应用; 甚至到通信报文内容也以xml格式来传递, 方便服务端数据在不同手机与开发平台上
解析. 因为不管是C++, C#, 还是Java语言都有提供相关API来解析XML格式内容.
在WM开发中, 可以使用微软提供的COM接口或者第三方开源XML解析库如TinyXML, 相关内容请自行浏览在Windows Mobile下使用MSXML, TinyXml 介绍,
12. 如何建立拨号链接进行网络通信
在WM中需先进行拨号链接操作, 链接成功建立后才可以进行后续的Socket通信等; 感觉这方面微软处理没有Symbian下那么友好, Nokia手机会在你的应用首次使用
网络时, 弹出窗口提醒你该操作可能产生GPRS流量费用, 询问你采用何种上网方式接入, 是cmnet还是cmwap. 因为讲述GPRS这方面文章很多, 可以直接看我整理的
Windows Mobile 开发系列文章收藏 - GPRS/上网设置.
13. 界面美化 - 贴图
用户对手机软件的界面是很在意的,做的好看了他会觉得有技术含量,做的好用了他会更加喜欢我们的产品。所以一套好的UI是必不可少的。手机软件开发的大部分
工程是在做UI系统。一套好的自主的手机软件UI系统是产品核心竞争力的一部分。在Windows Mobile的界面开发,使用C + SDK做漂亮的界面不容易,一旦在界面上控
件比较多,控件的布局更是头痛。横竖屏切换的时候也得考虑,不同手机屏幕尺寸可能也不一样; 不同的字体下, 界面差异也非常大……
其实要做出好的界面最后还是要回归RECT,也就是自己绘制贴图。 如果要做的很漂亮,那还是自己封装一套界面控件,这样控制起来方便。横竖屏问题,你绘制的
时候不应该写死的位置坐标,应该取相对坐标。在横竖屏切换的时候会触发WM_SIZE等一些消息,里面改变相对坐标的横竖屏大小就OK啦.
拿配置信息设置窗口来说, 主要需处理WM_PAINT, WM_MOUSEMOVE, WM_LBUTTONDOWN等一系列窗口消息.
最终实现效果大致如图下:
14. 用户登录过程例子
我是新开一个线程来处理, 可以灵活加入如超时控制等, 通过自定义处理消息来通知主窗体当前进度情况.这个你先定义这个消息如#define USER_LOGIN_MESSAGE
WM_USER + 300, 需要触发的时候SendMessage/PostMessage给指定窗口, 如PostMessage(g_hWnd, USER_LOGIN_MESSAGE, LOADCONFIG, 0); 然后
在对应的窗体消息处理里面处理, SendMessage和PostMessage后两个参数就对应WndProc的后两个参数,可用于传值。
LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
{
switch (message)
{
case USER_LOGIN_MESSAGE:
break;
}
return 0;
}
其效果大致如下图所示, 其中涉及菜单等操作可以看Windows Mobile入门中菜单部分.
15. 计算当前传输速率
在视频监控程序里面我们一般会在画面上同时显示当前传输速率为多少kbps, 我在这里采用通过2个变量来保存到上一秒收到的字节数以及到这一秒收到的数据量,
通过对这2数相减, 大致计算出这一秒传输了多大的数据量. 定义一个每隔1s触发的定时器, 然后在窗体中处理WM_TIMER消息. 为了能够上STATIC上字体显示成白色, 需在窗体中处理WM_CTLCOLORSTATIC消息
SetBkMode((HDC)wParam, TRANSPARENT);
SetTextColor((HDC)wParam, RGB(255, 255, 255));
return (LRESULT) GetStockObject(BLACK_BRUSH);
16. 如何制作.CAB安装包
C#怎么安装 cab呢?一般情况下通过vs 2005新建安装部署工程,里面就有打包cab来生成可部署到手机上的安装包. 另外有一个WinCE CAB Manager工具可以帮忙.
17. 模拟器 vs 真机
要弄清楚一点, 不管当前模拟器真实度有多么高, 但其毕竟不是真机; 如果条件可以的话, 尽早把程序部署到手机上跑跑看, 会发现一些在模拟器上没有注意到的问题, 如
网络情况, 稳定性, 传输速率. 当然还有其它一系列差异, 手机性能(CPU, 内存使用).
更多WM应用开发的常见问题, 可以看文章WM应用开发的常见问题解答, Windows Mobile 开发常见问题集2, Windows Mobile 开发系列文章收藏 - 开篇,
移动流媒体应用发展与限制
1. 资费问题
拿中国移动举例来说, 当前其GPRS是按流量来收费的; 就拿我自己动感地带套餐每月赠送50M流量, 按一路视频传输128kbps来计算, 让我们来看看, 可以看多少分钟
视频, 50M = 50 * 1024 * 8 (传输速率是按位计算的, 1 Byte = 8 bit), 结果是大致可以看50分钟, 如果把视频传输速率调低到32kbps, 我们也只能够看3小时多的
视频, 差不多也是当前智能手机电池能够支持极限, 当然这样处理同时也会降低视频画面的清晰度. 超出部分流量移动是按0.01¥/KB收取, 1分钟视频竟高达近10块大
洋.这个价格可不是像我这类的普通人承担得起的. 所以3G网络下, 中国联通率先对其资费进行了更改, 独创了全新的计费方式和计费理念:以M/T作为多媒体内容的下
载计费单位。可参见运营商的纠结:3G最好计费方式是什么模样
2. 网络状态, 无线网络带宽窄,干扰严重
我测试得到的情况是, 在办公室里面信号比较稳定, 平均传输速率在160 ~ 220kbps之间浮动. 下班回家在公交车上看视频, 视频所需缓冲时间加长, 画面显示需等待5-
10s不等, 在一些繁忙路口, 四周高楼大厦环境下, 存在信号盲区, 网络连接不上或者提示超时. 2.75G EDGE网络下(其速度最多236 kbps,对QCIF视频画面质量传
输来说足够了), 但实际情况下,稳定的传输速率通常在30 ~ 50kbps左右。并且随着使用用户的增加,网络的性能将会进一步下降。另外无线网络的干扰严重,
导致网络传输的误码的可能性大大增加。
当前的3G模块比较耗电. 未来随着3G的推广, 以及有消息称中国移动TD-LTE(4G)2010年会进入商用,下载一部164兆的电影,仅花了不到2分钟,而通常300兆的
电影,则只要3到5分钟就能下载完毕。对此,业内人士介绍,4G可以达到百兆以上的速率,对于3G来说又是一个质的飞跃。如果说3G 是国道,4G就是高速公路。
而对于4G与2G、3G之间最大的不同,技术人员介绍,除了速度比他们快之外,视频监控、视频通话效果也将更加流畅、高清。在网上看高清视频,不用担心画面卡或
声像不同步……与3G相比,4G带宽可达到170M以上,其下载速度比3G快80倍。
3. 手机自身缺陷(屏幕大小, CPU性能, 电池)
现在的智能手机性能上现在问题不大, 一些手机的CPU频率都超过600MHZ了, 还有消息称未来会有双核处理器的手机上市. 拿多普达的S1(220MHZ, 128M), 其运算
处理能力, 每秒解码15-20帧数据不成问题, 但考虑到网络等因素, 平均传输8 ~ 12fps比较合适. 但手机的CPU, 内存等提高, 必然会碰到的一个问题就是电池能源有限.
尽管手机设备的运算能力越来越强,但是由于它是由电池供电的,因此编解码处理不能太复杂,并且最好能够根据用户设备的电池来调整流媒体的接收和处理,能源管
理技术也是移动流媒体的一个研究热点。什么时候我们才能够用上完全使用太阳能, 提取人体产生能量或者其它新能源技术的手机呢.
终端系统平台、LCD多样化, 手机操作系统现在是类似于中国古代的战国时代, Symbian、Linux、Windows Mobile、Palm OS, 新近的苹果iPhone, 谷歌Android.
对于开发应用来说是一个机遇, 但反过来说同样也是一个巨大的挑战; 需适应的终端平台越来越多, 屏幕型号越来越走向多样化.
我对联通的WCDMA, 电信CDMA2000不太了解, 大家都可以谈谈当前3G发展情况, 运营商碰到的各种瓶颈, 如相关手机终端的缺乏, 基础网络建设等等. 在网上看到了
几个消息视频通话,3G最大谎言, 中国3G之父成都炮轰三大营运商“忽悠过了头”, 手机上网应用冷热不均 消费者感知重在实用, IT时代周刊封面文章:决战3G; 当然
也有一些其它消息, 中国移动定制的OPhone将在下个月上市了, Nokia也会在年底发布基于TD标准的3G手机, 加上其它厂商也会有一些手机上市, 手机终端缺乏问题
会得到一定程度上的解决. 各个运营商也都上马了手机软件商店, 如中移动Mobile Market 在本月已开张 三七分成, 但其会不会碰到中国式软件难题呢, 不好预测.
运营商:拿什么来吸引你,我的3G客户, 但不可否认移动互联网是一场革命, 它带给我们的将是生活模式、工作模式,以及思维模式的巨大改变!智能手机正加快策动二次PC革命, 手机的未来:一场想象力的盛宴; 国务院:积极发展移动多媒体、手机电视等文化也让我们看到了一线希望.
作者:peterzb(个人开发历程知识库 -
博客园)
出处:http://peterzb.cnblogs.com/
文章版权归本人所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。