GMobileSync开发环境搭建
前期的准备工作。
首先,搭建Windows Mobile开发平台,很简单,依次装下面这些软件就可以了。
- Microsoft Outlook 2 003。(Microsoft ActiveSync依赖它)
- Microsoft ActiveSync 4.5。(用于同步手机和模拟器)
- Visual Studio .Net 2005。(安装C#的时候要选上smart device)
- Windows Mobile 5.0 Pocket PC SDK。(GMobileSync采用WM5.0的SDK)
- .NET library for the Google Data API。
打开GMobileSync工程,在项目的References中,引用了
Google.GData.AccessControl
Google.GData.Calendar
Google.GData.Client
Google.GData.Extensions
如果引用无效,则重新在菜单Project -> Add References里面添加一下引用,对应的DLL文件在C:\Program Files\Google\Google Data API SDK\Redist\Mobile\WindowsMobile目录下。
第二步,如何调试。选择菜单Debug -> Start Debugging 之后会出现deploy对话框。如果你有手机并已经连线,你可以选择Windows Mobile 5.0 PocketPC Device ,或者你也可以选择Windows Mobile 5.0 PocketPC Emulator。
如果选择了Emulator,部署完成之后需要执行下面的步骤来建立网络连接:
- 在Tools菜单中打开Device Emulator Manager。
- 我们刚刚部署完成,可以看到Windows Mobile 5.0 PocketPC Emulator前面显示了一个绿色的箭头,表示模拟器正在运行。
- 在Windows Mobile 5.0 PocketPC Emulator上点击右键,选择Cradle。
- ActiveSync应该会自动和Emulator建立连接。如果没有,就在ActiveSync的菜单里面选择File -> Connection Settings。在打开的对话框中选中 Allow connections to one of the following,在它的下拉菜单中选择DMA。然后点击对话框右上角的Connect按钮,完成连接。
- OK,此时在模拟器上已经运行GMobileSync,可以测试它的功能了。
简单的看了一下 GMobileSync源代码。
- 程序的主要逻辑集中在frmMain.cs和GMobileSync.cs中。
- 程序的配置信息存放在/Application Data/GMobileSync/GMobileSync.xml中,包括用户名,密码,时区,上次同步过的事件等等。
- GMobileSync.IsReallyConnected() 会尝试下载"http://rareedge.com/gmobilesync/connected.txt",如果下载成功则表示WAP连接已经建立。感觉这种方法会影响速度,毕竟要访问国外的网站然后把文件下载下来。如果WM SDK中带有测试Internet连接的API,这里就可以得到改进吧。
- Google Calendar中的每个Event会有一个唯一的URL地址,Mobile Outlook里面的每个Appointment有一个唯一的ID。GMobileSync.xml里面会保存上次同步过的事件,形式就是<Appointment ID, Event URL>的pair。
- 为了日历的双向同步,需要能检查 Appointment或者Event是否改变。程序会为Appointment和Event计算md5,并且保存为Appointment的属性,GmsGoogleChecksum是Event的md5,GmsLocalChecksum是Appointment的md5。
GMobileSync的同步流程:
- 从Google Calendar中下载同步日期间的所有Event。
- 对于每个Event
- 出现在上次同步的列表(列表信息记录在GMobileSync.xml中)中
- 找到本地对于的Appointment,计算远程Event的md5 checksum,与本地Appointment的"GmsGoogleChecksum"属性比较
- checksum不相同,则用远程的Event信息更新本地的Appointment。
这说明如果自上次同步之后,本地和远程都对事件修改过,那么以远程修改为准,本地修改将被丢弃。 - Checksum相同,do nothing
- checksum不相同,则用远程的Event信息更新本地的Appointment。
- 找不到本地对应的Appointment,则Appointment自上次同步后在本地被删除,删除Event。
此时,远程修改将被丢弃。
- 找到本地对于的Appointment,计算远程Event的md5 checksum,与本地Appointment的"GmsGoogleChecksum"属性比较
- 不在上次同步的列表中,则根据Event信息新建Appointment。
- 出现在上次同步的列表(列表信息记录在GMobileSync.xml中)中
- 从Mobile Outlook中取得同步日期间的所有Appointment。
- 对于每个Appointment
- 存在"GmsLocalChecksum"属性
- 计算当前Appointment的md5 checksum,与记录的checksum比较,可以知道Appointment是否在本地被修改。
- 根据"GmsSelfUri"属性找到Appointment对应的Event的URL,然后测试Event是否存在。
- Event不存在,则删除本地Appointment。本地修改将被丢弃。
- Event存在,且Checksum不同,则更新远程的Event。
- Event存在,且Checksum相同,do nothing。
- 不存在"GmsLocalChecksum"属性,新Appointment,添加到Google Calendar。
- 存在"GmsLocalChecksum"属性
Last modified on 2009-01-24