Windows Mobile 5.0 开发学习

自上星期以来,开始系统化的学习Windows Mobile 5.0,希望通过系统化的学习,能够掌握移动开发。

Mobile 5.0开发配置:

软件安装顺序:

1. 安装Microsoft ActiveSync 4.0以上版本

2. 安装VS2005

开发Pocket PC需安装Windows Mobile 5.0 Pocket PC SDK

开发Smartphone需安装Windows Mobile 5.0 Smartphone SDK

Mobile 5.0环境配置:

1. 模拟器与Microsoft ActiveSync同步:

A.启动VS2005,在Tools->Device Emulator Manager,选择一个需要启动的模拟器,双击或者按右键,选择“Connect”,即启动模拟器。

 



B. 当模拟器启动后,在Device Emulator Manager中,右键该设备,选择“Cradle”,即可与Microsoft ActiveSync同步。

 



2. 模拟器上网:

启动模拟器后,只要PC机连接网络,模拟设备即能上网。

3.可能出现模拟器与Microsoft ActiveSync无法同步的现象,这种情况很可能发生,出现该情况,可以关闭VS2005,关闭Device Emulator Manager,然后再重新启动即可。
 

Mobile 5.0 最初的开发程序:

在Pocket Pc上新建1个应用程序:

在File->New->Project中可以选择Pocket PC或者Smartphone的Device Application

 



项目新建以后所看到的Form的界面是和真实设备的界面完全一致。

在Form上放置1个TextBox后,将值改成Pocket PC,运行该程序

 



在Pocket Pc右上角的有2种按钮,叉和ok,叉代表最小化,ok代表关闭。最小化程序会使得程序占用内存,在此觉得微软的操作系统提供的程序有些都是最小化,没有释放内存,会使得系统越跑越慢。

将最小化变为ok,通过设置form的属性MinimizeBox,true为最小化按钮,false为ok按钮。

在Smartphone中没有上述的变化,在Smartphone中,如果不添加menu中的事件来结束程序的话,那程序始终会以最小化方式保留在系统内部。

更改应用程序的平台:

选择project,右键,在菜单中选择“Change Target Platform”

 



在选择平台中,选择一个你想改变的平台,按OK即可

注:Pocket Pc和SmartPhone平台改换后,要更改下列内容:

1. 控件的大小

2. 某些特定控件在SmartPhone中不支持,如Button

3. 某些托管API。SmartPhone中,所支持的API没有Pocket PC多

开发Mobile需要注意:

由于是基于移动设备的,所以无论cpu还是内存来说,都和PC有很大差距,所以要求消耗较少的内存开销,另外相比PC来说,所支持的API是非常少的,需要经常查SDK。

 

在开发Mobile Web Site之前,准备工作:

1. 确认IIS可以正常启动。

2. VS2005能够以HTTP方式正常创建Web Site。

3. 至少有1个模拟器,Pocket PC,Smartphone,Openwave。

新建1个空的站点,在站点中添加一个Mobile Web Form,命名为index.aspx。

将该页面切换到Design模式,可以发现页面上的Form的宽度非常小而且是固定的,这是因为该页面与实际设备上显示的页面会保持一致。

控件的breakAfter属性,true表示控件render后会多添加一个换行符。

Mobile Web Form与Web Form之间的区别:

1. 控件Tag标签:

      Web Form:控件标签都以<asp:xxxx></asp>,atlas以前是以<atlas:xxxx></atlas>,现在也都统一成
                           <asp:xxxx></asp>形式了。

      Mobile Web Form:控件标签以<mobile:xxxx></mobile>

2. Mobile Web Form中可以添加的控件:(在Design中,Toolbox中)

      Standard:只能用于WM操作。

      Mobile Web Form:可以适用于任何移动设备浏览器,可能显示效果不一样,特殊控件需要根
                                       据设备进行效果调整。

3. Mobile Web Form上可以放置多个Form,而Web Form只能有1个Form。

4. Mobile Web Form不支持MasterPage,而Web Form支持。


一个站点中可以包含Web Form和Mobile Web Form,Mobile Web Form上的控件推荐都采用Toolbox中Mobile Web Form面板内的控件。针对不同平台的浏览器,定制一些适用于该平台的设置,Mobile Web Form中的所有Mobile控件都支持定制。

控件定制:

在控件的Properties的Property Overrides,选择Edit按钮,在Applied Device Filters中选择一个过滤器,选择好后按Edit编辑参数,Compare用于根据什么比较,Argument是该如果比较项等于该参数就满足该过滤器的条件,就可以按照你自己定义的这个效果显示。


Mobile Web Form的数据邦定控件ObjectList Control

可以用DataSource指定数据源,支持Template,共有3类Template。

1.Header and Footer Templates

2.Item Templates

3.Separator Template。

补充:一旦设置了某个Template,那默认的显示就消失了。

我只设置了Header和Footer,并没有设置Item,但是系统为认为Item也是设置的,只不过没有内容而已。另外,只有为ObjectList Control控件定制以后才能进行Template的编辑。



在Mobile Web Form上可以放置多个Form,Form的形式是以组件的形式加载的,当用户对该Form所在的Web Form发出请求后,就会将该Web上的所有Form全部加载,以减少在切换Form时的时间。同一Web上的不同Form间切换只传递的是一些数据,具体可以使用Openwave后看下请求和相应效果。

另外对于Openwave,由于在Openwave sdk 6.2.2中页面的button会显示出来,而不是当焦点移过去后,SoftKey左键会有button的显示,较早版本的Openwave中会有该效果的。

参考文章:

Customizing ASP.NET Mobile Web Controls for Specific Devices

补充在(2)中的内容:

Mobile Web Form与Web Form的区别:

Mobile Web Form不支持Theme,但Mobile Web Form可以使用StyleSheet。

修改(1)的内容:

当模拟器和Microsoft ActiveSync无法同步时,可以按照下列步骤就可以立即恢复同步。
1.在Tools->Device Emulator Manager中,选择正在同步的设备右键,选择"Uncradle"。
2.打开Microsoft ActiveSync,按connect,这时候会出现同步画面。
3.在Tools->Device Emulator Manager中,选择"Cradle"继续同步。

Mobile页面上调用所有Asp.net的控件必须订制。

在Mobile Web Form中使用javascript的方法:

由于有些手机能够支持javascript,所以只有支持javascript的手机才能显示出效果,所以需要定制,在支持的手机中实现javascript效果。

涉及代码:

     < mobile:Form  id ="Form1"  runat ="server"  OnLoad ="Form1_Load" >
        
< mobile:Label  ID ="Label1"  Runat ="server"  Font-Bold ="True" > Student Name: </ mobile:Label >
        
< mobile:TextBox  ID ="txtStName"  Runat ="server" ></ mobile:TextBox >
        
< mobile:Command  ID ="Command1"  Runat ="server"  OnClick ="Command1_Click1" > Get Info </ mobile:Command >
        
< mobile:Command  ID ="Command2"  Runat ="server" > Client Event </ mobile:Command >
        
< mobile:Panel  ID ="Panel1"  Runat ="server" >
            
< mobile:DeviceSpecific  ID ="DSP1"  Runat ="server" >
                
< Choice  Filter ="isHTML32"  Xmlns ="http://schemas.microsoft.com/mobile/html32template" >
                    
< ContentTemplate >
                    
< asp:CheckBox  ID ="chkBox"  runat ="server"  Text ="CheckBox Control"   />
                    
< Script  language ="jscript"  for ="window"  event ="onload" >
                            window.Form1.Command1.onclick 
= ShowMsg;
                            
function ShowMsg(e)
                            
{
                                alert(
"Msg!");
                            }

                        
</ Script >
                        
< Script  language ="jscript"  for ="Command2"  event ="onclick" >
                            alert(
"Msg!");
                        
</ Script >  
                    
</ ContentTemplate >
                
</ Choice >
            
</ mobile:DeviceSpecific >
        
</ mobile:Panel >
    
</ mobile:Form >



其中在panel中放置定制<mobile:DeviceSpecific ID="DSP1" Runat="server">

定制条件是只要支持HTML就行<Choice Filter="isHTML32">

在ContentTemplate中插入script代码,其中for是针对的控件,Mobile Web Form中用window代替document。Event表示对于指定的控件,出现指定的事件时执行scipt中的操作。

第一个script中,当页面onload的时,执行script,并指定command1的onclick事件。
第二个script中,只有当command2点击时,才执行script。

在ContentTemplate中就能添加asp.net控件,更能添加atlas等。

关于script的属性可以看MSDN的SCRIPT Element | script Object

里面对script的每个属性,使用方法都有实例。

补充在(2)中的内容:

Mobile Web Form与Web Form的区别:

Mobile Web Form不支持Theme,但Mobile Web Form可以使用StyleSheet。

修改(1)的内容:

当模拟器和Microsoft ActiveSync无法同步时,可以按照下列步骤就可以立即恢复同步。
1.在Tools->Device Emulator Manager中,选择正在同步的设备右键,选择"Uncradle"。
2.打开Microsoft ActiveSync,按connect,这时候会出现同步画面。
3.在Tools->Device Emulator Manager中,选择"Cradle"继续同步。

Mobile页面上调用所有Asp.net的控件必须订制。

在Mobile Web Form中使用javascript的方法:

由于有些手机能够支持javascript,所以只有支持javascript的手机才能显示出效果,所以需要定制,在支持的手机中实现javascript效果。

涉及代码:

     < mobile:Form  id ="Form1"  runat ="server"  OnLoad ="Form1_Load" >
        
< mobile:Label  ID ="Label1"  Runat ="server"  Font-Bold ="True" > Student Name: </ mobile:Label >
        
< mobile:TextBox  ID ="txtStName"  Runat ="server" ></ mobile:TextBox >
        
< mobile:Command  ID ="Command1"  Runat ="server"  OnClick ="Command1_Click1" > Get Info </ mobile:Command >
        
< mobile:Command  ID ="Command2"  Runat ="server" > Client Event </ mobile:Command >
        
< mobile:Panel  ID ="Panel1"  Runat ="server" >
            
< mobile:DeviceSpecific  ID ="DSP1"  Runat ="server" >
                
< Choice  Filter ="isHTML32"  Xmlns ="http://schemas.microsoft.com/mobile/html32template" >
                    
< ContentTemplate >
                    
< asp:CheckBox  ID ="chkBox"  runat ="server"  Text ="CheckBox Control"   />
                    
< Script  language ="jscript"  for ="window"  event ="onload" >
                            window.Form1.Command1.onclick 
= ShowMsg;
                            
function ShowMsg(e)
                            
{
                                alert(
"Msg!");
                            }

                        
</ Script >
                        
< Script  language ="jscript"  for ="Command2"  event ="onclick" >
                            alert(
"Msg!");
                        
</ Script >  
                    
</ ContentTemplate >
                
</ Choice >
            
</ mobile:DeviceSpecific >
        
</ mobile:Panel >
    
</ mobile:Form >



其中在panel中放置定制<mobile:DeviceSpecific ID="DSP1" Runat="server">

定制条件是只要支持HTML就行<Choice Filter="isHTML32">

在ContentTemplate中插入script代码,其中for是针对的控件,Mobile Web Form中用window代替document。Event表示对于指定的控件,出现指定的事件时执行scipt中的操作。

第一个script中,当页面onload的时,执行script,并指定command1的onclick事件。
第二个script中,只有当command2点击时,才执行script。

在ContentTemplate中就能添加asp.net控件,更能添加atlas等。

关于script的属性可以看MSDN的SCRIPT Element | script Object

里面对script的每个属性,使用方法都有实例。

补充在(2)中的内容:

Mobile Web Form与Web Form的区别:

Mobile Web Form不支持Theme,但Mobile Web Form可以使用StyleSheet。

修改(1)的内容:

当模拟器和Microsoft ActiveSync无法同步时,可以按照下列步骤就可以立即恢复同步。
1.在Tools->Device Emulator Manager中,选择正在同步的设备右键,选择"Uncradle"。
2.打开Microsoft ActiveSync,按connect,这时候会出现同步画面。
3.在Tools->Device Emulator Manager中,选择"Cradle"继续同步。

Mobile页面上调用所有Asp.net的控件必须订制。

在Mobile Web Form中使用javascript的方法:

由于有些手机能够支持javascript,所以只有支持javascript的手机才能显示出效果,所以需要定制,在支持的手机中实现javascript效果。

涉及代码:

     < mobile:Form  id ="Form1"  runat ="server"  OnLoad ="Form1_Load" >
        
< mobile:Label  ID ="Label1"  Runat ="server"  Font-Bold ="True" > Student Name: </ mobile:Label >
        
< mobile:TextBox  ID ="txtStName"  Runat ="server" ></ mobile:TextBox >
        
< mobile:Command  ID ="Command1"  Runat ="server"  OnClick ="Command1_Click1" > Get Info </ mobile:Command >
        
< mobile:Command  ID ="Command2"  Runat ="server" > Client Event </ mobile:Command >
        
< mobile:Panel  ID ="Panel1"  Runat ="server" >
            
< mobile:DeviceSpecific  ID ="DSP1"  Runat ="server" >
                
< Choice  Filter ="isHTML32"  Xmlns ="http://schemas.microsoft.com/mobile/html32template" >
                    
< ContentTemplate >
                    
< asp:CheckBox  ID ="chkBox"  runat ="server"  Text ="CheckBox Control"   />
                    
< Script  language ="jscript"  for ="window"  event ="onload" >
                            window.Form1.Command1.onclick 
= ShowMsg;
                            
function ShowMsg(e)
                            
{
                                alert(
"Msg!");
                            }

                        
</ Script >
                        
< Script  language ="jscript"  for ="Command2"  event ="onclick" >
                            alert(
"Msg!");
                        
</ Script >  
                    
</ ContentTemplate >
                
</ Choice >
            
</ mobile:DeviceSpecific >
        
</ mobile:Panel >
    
</ mobile:Form >



其中在panel中放置定制<mobile:DeviceSpecific ID="DSP1" Runat="server">

定制条件是只要支持HTML就行<Choice Filter="isHTML32">

在ContentTemplate中插入script代码,其中for是针对的控件,Mobile Web Form中用window代替document。Event表示对于指定的控件,出现指定的事件时执行scipt中的操作。

第一个script中,当页面onload的时,执行script,并指定command1的onclick事件。
第二个script中,只有当command2点击时,才执行script。

在ContentTemplate中就能添加asp.net控件,更能添加atlas等。

关于script的属性可以看MSDN的SCRIPT Element | script Object

里面对script的每个属性,使用方法都有实例。

 

Mobile程序部署:将自己开发的Mobile WinForm程序部署到设备上。

新建1个Project,该程序启动后就显示系统时间。


程序很简单,就是在Form_Load事件中,将Label的Text值设置为系统时间。

编译后,运行到模拟设备上,进行测试。


程序显示正常,那可以进行部署了。

在Solution中添加1个Project,选择Solution->Add->New Project

选择Other Project types->Setup And Deployment->Smart Device CAB Project

新建1个CAB的Project。

新建完后,出现配置界面:


在File System on Target Machine中可以添加不同的文件夹,在不同的文件夹内可以添加相应的处理。默认的情况会有Application Folder和Program Files Folder这2个文件夹,但里面内容都是空的。

为了在设备上的Start Menu菜单和Programs文件夹内有快捷方式,我添加了这2个文件夹。

在Application Folder中添加程序主体:


在Application Folder中添加一个Project Output,选择Primary output

快捷方式的添加:

选择一个Folder,在旁边一栏,右键选择Create New Shortcut,在对话框中选择Application Folder,将Primary output添加进来。


在Solution Explorer中,选择CAB Project中的Primary output,打开它的属性


在Outputs中可以察看部署到设备中的实际的内容。

打开ActiveSync程序,选择Explore


我将CAB复制到设备中。然后打开设备,在文件管理器中执行该CAB

安装完毕后,查看Start菜单,程序部署成功。

在图中的DemoDeployment是我的WinForm的Project名

http://www.sf.org.cn/windowsmobile/windowsmobilerumen/Index.html

转载于:https://www.cnblogs.com/bluespot/archive/2008/03/08/1096267.html

  • 0
    点赞
  • 0
    收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:编程工作室 设计师:CSDN官方博客 返回首页
评论
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值