一个简单的WInCE(转载百度)

VS2008中开发智能设备程序的一些总结收藏1

结合前几日开发的《全国大坝基础数据库采集端》中的PDA程序开发过程,对VS2008开发智能设备上的程序做个小总结。

1        
程序结构

程序中包括四个部分:

1. 系统配置

这个部分用来配置系统中的相关参数,参数包括数据库信息和串口的配置信息。这部分的主要技术是XML文件的读取和写入。

2. 数据下载

从数据库中下载数据到PDA,PDA上的保存也是使用数据库。这部分的技术主要是PDA设备上的移动数据库开发和使及用PDA连接PC数据库

3. 数据上传

把PDA上的数据上传到PC数据库中,使用的技术和2相同。

4. GPS数据获取

通过外置蓝牙GPS模块获取当时所在位置的经纬度,并将经纬度保存在PDA上的移动数据库中。涉及到的技术有串口数据的读取,GPS数据的解析。

2         开发环境

软件环境: Visual studio 2008

PC数据库: sql server

智能设备: Windows Mobile 6

3        
建立工程3.1      建立项目

建立工程的过程和VS建立其他工程步骤相同,通过vs2008中的菜单“文件-新建-项目 ”,建立一个新项目。

VS2008已经集成了智能设备的开发环境,根据开发语言的不同,在不同的开发语言树中选择“智能设备”,下方的名称中填写项目名称,点击“确定”按钮,就建立了一个智能设备的程序项目。

3.2      建立调试环境

VS2008中已经包括了智能设备的仿真程序,编写的程序可以通过PC机上的仿真程序进行调试,不必在PDA上逐个调试程序。

建立项目后,通过菜单“项目--项目属性”中的“设备”页中设置调试内容。

在下拉框中,选择目标设备的类型。类型的选择要根据PDA的操作系统进行确定,PDA上如果是中文操作系统,请选择“CHS”打头的选项。具体如何选择,请根据PDA的操作系统进行。如果对选项中的内容不了解,请查阅其他资料。

仿真程序的选择和设置不仅仅只有这一种方式,也可以通过VS2008中的“工具-设备仿真器管理器”进行设置。

3.3     
绘制窗体

智能设备的窗体和windows窗口的差别不是很大。在工程中选择添加窗体后,VS中出现PDA屏幕模样的模板。需要什么功能,在工具箱中把对应的控件拖到模板上即可。这部分的开发和普通的Windows程序开发没有什么不同。

不同的部分就是菜单。智能设备的菜单中有缺省菜单,就是在屏幕底部有个菜单控件,可以通过增加菜单项的方式增加菜单。需要注意的是,一级菜单只能有两个,而且设置的时候,只能先设置左边的菜单项内容,才能设置右边菜单项内容。

控件的使用也是有严格限制的。VS2008中能使用的控件分布在工具箱的“所有设备控件V、“公共设备控件 v、“设备容器
v、“设备菜单和工具栏V、“设备数据V、“设备组件V、“设备对话框V。使用控件的方式和Windows窗体的设计没有什么不同。

4        
调试

调试程序的方式同普通的程序调试差别不大,也通过单步调试等等的功能。唯一的差别就在于调试中程序在仿真器中运行。

4.1      其他文件

在调试中,程序如果只有一个EXE文件,而不涉及到其他文件,可以直接在仿真程序中运行。但是如果程序还有其他文件的话,需要把文件也要部署到PDA仿真器上。如何部署其他文件,请参考下面步骤:

1. 通过仿真器上的菜单“文件――配置…”菜单设置共享文件夹。

通过后面的按钮,浏览电脑中的磁盘,并选择恰当的目录。“共享文件夹”在设置完成后,将作为PDA仿真器的扩展存储空间,仿真器中共享文件夹被命名为“Storage
Card”。那么在仿真器中就可以直接操作共享文件夹中的文件。

这时候,就可以把其他和程序相关的文件拷贝到需要的地方。下面以一个XML文件为例。这个XML和程序的可执行程序在一个目录下,用来保存程序的设置参数。XML文件在电脑上,程序中通过读取可执行程序所在的目录来指定XML文件的目录。但是很不幸,仿真器在运行过程中,认为EXE可执行程序在“program
files\\项目名称”这个目录下,这个目录是仿真器中的路径,肯定是不会找到XML文件的。这就需要把XML文件也放置到“program
files\\项目名称”目录下面去。

在仿真器中点击“开始-资源管理器”,打开后选择“Storage
Card”。在这个里面通过目录-文件的方式选中文件,然后点击下面的“菜单-编辑-复制”,将文件复制出来。

然后通过仿真器界面上的文件-目录功能,找到“我的设备-program
files-项目名称”,进入以项目名称为名称的目录,通过“文件-编辑-粘帖”,把文件拷贝到可执行程序所在的运行目录下。

5         移动数据库

在这个项目中,使用的是微软的SQL SERVER Mobile Compact Editor 3.5。其他的数据库还没有使用过。仅仅就SQL SERVER
Mobile Compact Editor 3.5的使用方法说明。

5.1      获得SQL SERVER Mobile
Compact Editor 3.5

SQL SERVER Mobile Compact Editor 3.5可以直接从微软的网站上下载,网址为:http://www.microsoft.com/downloads/details.aspx?familyid=7849B34F-67AB-481F-A5A5-4990597B0297&displaylang=zh-cn

下载后在电脑上进行安装。默认安装到C:\Program Files\Microsoft SQL Server Compact Edition下。

3.5版本为最新版,增加了设置数据库文件密码的功能。也可以使用其他版本的SQL SERVER MOBILE替代。

5.2     
在SQL SERVER MANAGER STUDIO中使用SQL SERVER MOBILE

在登录部分,服务器类型选择“SQL SERVER
MOBILE”,数据库文件通过下拉框中的“浏览更多…”选择建立的数据库文件,也可以通过选择窗体中的“新建数据库”建立新的数据库。

输入数据库密码,即可登录到SQL SERVER MOBILE数据库中。需要说明的是,3.5版本建立的数据库,在SQL SERVER MANAGE
STUDIO 2005中可能无法登录。

5.3      Sql server
mobile数据库中建立数据表

Sql server mobile中建表可以通过sql server manage studio
2005中的建表向导进行建表,也可以通过sql语句进行建表。建表的时候需要注意字段类型和sql server中的字段类型并不相同,在sql
server中能使用的字段类型,在sql server mobile中可能无法使用,在建表的过程中需要注意这点。

5.4     
在智能设备上部署sql server Mobile数据库

把建好的数据库文件通过4.1中描述的方式,拷贝到相应的仿真器目录下。这时候仿真器就可以连接并操作SQL SERVER MOBILE数据库了。

但是如果使用PDA访问SQL SERVER MOBILE,注意Windows
Mobile中不包含数据库引擎,需要额外的安装四个包。如果不安装这四个包,程序将无法连接和读取SQL SERVER MOBILE数据库。

这四个包在sql server mobile安装目录下,具体的是C:\Program Files\Microsoft SQL Server Compact
Edition\v3.5\Devices\wce500\armv4i目录下面,包括:

sqlce.dev.CHS.ppc.wce5.armv4i.CAB

sqlce.ppc.wce5.armv4i.CAB

sqlce.repl.ppc.wce5.armv4i.CAB

sqlce.wce5.armv4i.CAB

将这四个文件拷贝到仿真器上,并安装。

安装后,PDA的程序中增加了三个程序: sqlservercompact 3.5 Repl

SqlserverCompact 3.5 Tools CN

SqlserverCompact 3.5 Core

当不用移动数据库时,可以卸载这三个程序。

6        
智能设备连接操作PC数据库

智能设备操作PC数据库,有两种方式:

一种是通过无线连接,一种是通过USB连接到电脑上。无线连接在普通环境下使用普遍性不足,很多情况下是通过USB数据线进行连接的。使用USB数据线连接,PC电脑上需要安装同步工具,目前使用较多的为微软的ActiveSync,下载地址是;

http://www.microsoft.com/downloads/details.aspx?FamilyID=cabdb564-ae94-4c02-abbc-cdece61231d4&DisplayLang=zh-cn

智能设备和PC同步后,就可以把智能设备看作一台电脑,可以连接数据库。

7        
数据库连接字符串7.1   Sql server mobile

在工程中增加引用,引用System.data.sqlserverCe

类中使用命名空间:System.data.sqlserverCe

数据库链接类名、命令类名及记录集类名中都使用包含Ce的类。

具体代码如下:
using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.Data;

using System.Drawing;

using System.Text;

using System.Windows.Forms;

using System.Data.SqlServerCe;

using System.Data.SqlClient;

namespace GPSDataReader

{

public partial class frmDamUp : Form

{

SqlCeConnection ConnMobile;

SqlCeCommand command;

public frmDamUp()

{

InitializeComponent();

}

private void frmDamUp_Load(object
sender, EventArgs e)

{

//获取可执行程序所在目录和数据库文件

string
sFilePath =
System.IO.Path.GetDirectoryName(System.Reflection.Assembly.GetExecutingAssembly().GetName().CodeBase)
+ "";

//连接sql server
Mobile数据库的连接字符串

string
ConnStr = "Data Source=" + sFilePath + ";Persist Security
Info=False;password=admin;";

//建立链接

ConnMobile
= new SqlCeConnection(ConnStr);

try

{

ConnMobile.Open();

}

catch
(Exception ex)

{

MessageBox.Show("不能正确连接移动数据库!" + ex.Message);

this.Close();

}

command =
new SqlCeCommand();

command.Connection = ConnMobile;

string
sqlstr = "select * from DamInfo where IsUP=‘1‘";

command.CommandText = sqlstr ;

SqlCeDataReader rs = command.ExecuteReader();

while
(rs.Read())

{

ListViewItem lv_Item = new ListViewItem();

lv_Item.Text = rs["RSID"].ToString();

lv_Item.SubItems.Add(rs["RSNM"].ToString());

lv_Item.SubItems.Add(rs["DMPRV"].ToString());

lv_Item.SubItems.Add(rs["DMCT"].ToString());

lv_Item.SubItems.Add(rs["DMTW"].ToString());

lv_Item.SubItems.Add(rs["EL"].ToString());

lv_Item.SubItems.Add(rs["NL"].ToString());

lv_Item.SubItems.Add("未上传");

lv_DamInfo.Items.Add(lv_Item);

}

rs.Close();

if
(lv_DamInfo.Items.Count == 0)

{

MessageBox.Show("没有需要上传的数据!");

this.Close();

}

}

7.2      智能设备连接PC上的SQL
SERVER
智能设备不支持OLEDB连接方式,只能使用SQLSERVER
.Net的连接方式。所以增加System.data.SqlClient引用。在需要连接的类中增加System.data.SqlClient命名空间。

代码如下:

using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.Data;

using System.Drawing;

using System.Text;

using System.Windows.Forms;

using System.Data.SqlServerCe;

using System.Data.SqlClient;

private void b_Down_Click(object sender, EventArgs e)

{

string sqlstr;

string Connstr = "user
id=sa;password=2centit13;initial catalog=DamBase;Server=" + ConfigInfo.IP +
";Connect Timeout=30";

SqlConnection Conn = new SqlConnection(Connstr);

try

{

Conn.Open();

}

catch
(Exception ex)

{

MessageBox.Show("无法连接到指定的PC数据库!" + ex.Message);

return;

}

}

《===========================================================》

接触之后才发现,原来WINCE是本来就有这种项目。

一个简单的WInCE(转载百度),码迷,mamicode.com

时间: 2024-12-26 16:56:47

一个简单的WInCE(转载百度)的相关文章

230行实现一个简单的MVVM(转载)

https://zhuanlan.zhihu.com/p/24475845 作者:mirone链接:https://zhuanlan.zhihu.com/p/24475845来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 题图的PixivID为:pixiv-ID: 14402942,画师为RAHWIA 本文始发于我的博客,转载请注明作者. MVVM这两年在前端届掀起了一股热潮,火热的Vue和Angular带给了开发者无数的便利,本文将实现一个简单的MVVM,用20

网上看来的:进程与线程的一个简单解释《转载》

原文作者: 阮一峰  发布时间: 2013-05-07 19:28 http://kb.cnblogs.com/page/176246/ 进程(process)和线程(thread)是操作系统的基本概念,但是它们比较抽象,不容易掌握. 最近,我读到一篇材料,发现有一个很好的类比,可以把它们解释地清晰易懂. 1. 计算机的核心是CPU,它承担了所有的计算任务.它就像一座工厂,时刻在运行. 2. 假定工厂的电力有限,一次只能供给一个车间使用.也就是说,一个车间开工的时候,其他车间都必须停工.背后的含

一个简单网络爬虫示例(转载)

在学生时期,可能听到网络爬虫这个词会觉得很高大上,但是它的简单实现可能学生都不难懂. 网络爬虫应用,就是把整个互联网真的就当做一张网,像蜘蛛网那样,应用就像一个虫子,在网上面按照一定的规则爬动. 现在互联网应用最广的就是http(s)协议了,本文例子就是基于使用http(s)协议的,只作为示例,不涉及复杂的算法(实际上是最重要的). 设计思路: 程序入口从一个或多个url开始,通过http(s)获取url的内容,对获取到内容处理,获取内容中需要爬取的信息,获取到内容中的url链接,再重复以上步骤

对一个简单的时间片轮转多道程序内核代码的浅析

这周在网易云课堂上学习了<Linux内核分析>——操作系统是如何工作的.本周学习内容有利用 mykernel 实验模拟计算机平台和利用 mykernel 实验模拟计算机硬件平台两部分内容. 这是实验楼中 mykernel 平台运行的结果: 下面是一段一个简单的时间片轮转多道程序内核代码: 1 /* 2 * linux/mykernel/myinterrupt.c 3 * 4 * Kernel internal my_timer_handler 5 * 6 * Copyright (C) 201

分享:计算机图形学期末作业!!利用WebGL的第三方库three.js写一个简单的网页版“我的世界小游戏”

这几天一直在忙着期末考试,所以一直没有更新我的博客,今天刚把我的期末作业完成了,心情澎湃,所以晚上不管怎么样,我也要写一篇博客纪念一下我上课都没有听,还是通过强大的度娘完成了我的作业的经历.(当然作业不是百度来的,我只是百度了一些示例代码的意思,怎么用!算了,越解释万一越黑呢!哈哈O(∩_∩)O哈哈~) ----------------------------------------------------------------分界线------------------------------

一个简单的开源PHP爬虫框架『Phpfetcher』

这篇文章首发在吹水小镇:http://blog.reetsee.com/archives/366 要在手机或者电脑看到更好的图片或代码欢迎到博文原地址.也欢迎到博文原地址批评指正. 转载请注明: 吹水小镇 | reetsee.com 原文链接地址: http://blog.reetsee.com/archives/366 ------------------------------ 好久不见了!我终于又写一篇日志了,本来有很多流水帐想发但是感觉没营养,就作罢了.今天我主要分享一个简单的PHP爬虫

开发一个简单实用的android紧急求助软件

之前女朋友一个人住,不怎么放心,想找一个紧急求助的软件,万一有什么突发情况,可以立即知道.用金山手机卫士的手机定位功能可以知道对方的位置状态,但不能主动发送求助信息,在网上了很多的APK,都是鸡肋功能,都需要解锁.并打开软件,真正的紧急情况可能没有时间来完成这一系列操作. 于是我自己做了一个这样的软件,在紧急情况下,连续按电源键5次即可发送求救短信和位置信息给事先指定的用户,这个操作在裤兜里就能完成.原理很简单,就是设置监听器捕获屏幕的开关,在较短的时间内屏幕开关达到一定次数后,触发手机定位,定

用GO语言实现一个简单的搜索引擎

用GO语言实现一个简单的搜索引擎 项目地址是:https://github.com/wyh267/FalconEngine 对搜索引擎感兴趣的可以去看看这本书,比较浅并且也比较完整的介绍了一个搜索引擎的全部机能. 我的这个搜索引擎原始数据是MySql数据库的,大家可以根据需要进行二次开发,用来支持其他数据库或者本地文件,Detail文件是存储在Redis数据库中,同样这部分也可以根据自己的需要二次开发,使用本地文件或者其他数据库,倒排索引和正排索引本地存储的时候使用的json格式,比较耗磁盘,第

Windows 上静态编译 Libevent 2.0.10 并实现一个简单 HTTP 服务器(无数截图)

[文章作者:张宴 本文版本:v1.0 最后修改:2011.03.30 转载请注明原文链接:http://blog.s135.com/libevent_windows/] 本文介绍了如何在 Windows 操作系统中,利用微软 Visual Studio 2005 编译生成 Libevent 2.0.10 静态链接库,并利用 Libevent 静态链接库,实现一个简单的 HTTP Web服务器程序:httpd.exe. 假设 Visual Studio 2005 的安装路径为“D:\Program