SideShow Gadget开发[2]

简介: 上次在SideShow Gadget开发[1]中介绍了本地Gadget的开发,现在介绍一下常规Gadget的开发。

上次在SideShow Gadget开发[1]中介绍了本地Gadget的开发,现在介绍一下常规Gadget的开发。

在介绍Gadget之前,我们先说一下我们认识上的一个误区,很多开发人员认为常规Gadget和本地Gadget类似,是一个.Net Micro Framework应用程序(至少是一个DLL),在连接时,由PC端把该DLL下载到Sideshow设备上去,Sideshow主程序加载并运行该程序。我一开始也是这样认为的,但是随着开发的深入,对Sideshow的运行机理也越来越了解,其实常规Gadget更像一个网页应用,普通的网页浏览基于http协议,而Gadget基于SCFSimple Content Format,目前sideshow支持两种协议,另一种是ICAL,在Sideshow中不称为通信协议,专业术语是endpoint)协议,此时的Gadget更像一个网页,而Sideshow设备更像一个IE客户端。

从以上描述,你就会明白了,其实没有什么DLL,对于Sideshow设备来说仅有一些基于SCF格式的数据流而已。

所以开发常规Gadget理论上不拘于什么开发语言,只要能输出符合SCF格式的数据流即可。不过这里还是推荐使用C#(或基于.NET开发平台开发语言),可以直接引用相关开发库,非常简单的生成符合SCF格式的界面要素。

下面先“秀”一下我们已经开发好的图片浏览Gadget,然后再介绍一下是如何开发的。

1、      安装后,会在Sideshow控制面板上出现如下图标

mf1

2、可以设置PC上要共享的图片目录

 

mf2

3、在Sideshow设备上的显示

 

mf3

4、按左右键进行图片浏览

 

mf4

5、显示图片,也可以通过listbox进行选择

 

 

下面简单介绍一下相关代码:

 

1、  两个GUIO

一个是GadgetGUIDSideshow管理程序通过这个GUID加载相对应的Gadget

一个是该Gadget对应的属性页的GUID(在代码中,属性页其实就是一个标识了GUID的控件,该控件派生于Microsoft.SideShow.GadgetPropertyPage),Sideshow管理程序加载并显示属性对话框。

注意:在注册时,一定保证VS2008或相关程序具有管理员权限,否则操作注册表会失败。

2、  注册代码

GadgetRegistration.Register

    (

    false,                                       //true 对全部用户有效  false 对当前用户有效                

    GadgetId,                                    //gadgetID 

    ScfSideShowGadget.ScfEndpointId,             //内容端点,需要使用SCF

    "Picture Share",                             //SideShow控制面板中显示的名字

    "/"" + Assembly.GetEntryAssembly().Location + "/"",      //程序所在的路径

    String.Format("/"{0}/",{1}", Assembly.GetEntryAssembly().Location, -GadgetRegistration.DefaultIconResourceId),    //程序图标位置

    false,                                       //True  连接时才显示内容,false 不用连接也能显示内容                   

    GadgetCachePolicies.KeepNewest,              //接收消息项的策略  KeepNewest保留最新 KeepOldest保留最老 KeepFrequentlyAccessed保留最频繁 KeepRecentlyAccessed保留最近以前没有收到的消息

    new Guid("9B84055E-E253-4119-8719-F684ECB9FBC1")      //属性页ID

   );

3、  事件设置

YFGadget = new Microsoft.SideShow.SimpleContentFormat.ScfSideShowGadget(new Guid(GadgetEntry.Gadget_GUID));

#region Listen to SideShow Events

// Subscribe to events from the Windows SideShow platform.

YFGadget.AllDevicesRemoved += new System.EventHandler(OnAllDevicesRemoved);

YFGadget.ContentMissing += new System.EventHandler<Microsoft.SideShow.ContentMissingEventArgs>(OnContentMissing);

YFGadget.ContentNavigate += new System.EventHandler<Microsoft.SideShow.SimpleContentFormat.ContentNavigateEventArgs>(OnContentNavigate);

YFGadget.ContextMenuSelect += new System.EventHandler<Microsoft.SideShow.SimpleContentFormat.ContextMenuSelectEventArgs>(OnContextMenuSelect);

YFGadget.DeviceAdded += new System.EventHandler<Microsoft.SideShow.DeviceCapabilityEventArgs>(OnDeviceAdded);

YFGadget.DeviceRemoved += new System.EventHandler<Microsoft.SideShow.DeviceCapabilityEventArgs>(OnDeviceRemoved);

YFGadget.GadgetEnter += new System.EventHandler(OnGadgetEnter);

YFGadget.GadgetExit += new System.EventHandler(OnGadgetExit);

YFGadget.MenuSelect += new System.EventHandler<Microsoft.SideShow.SimpleContentFormat.MenuSelectEventArgs>(OnMenuSelect);

#endregion

         4、传送图片、菜单等

//枚举当前路径下的所有图片

string[] strPath = Directory.GetFiles(SharePath);

List<string> strImgPath = new List<string>();

 

foreach (string path in strPath)

{

    if (path.Length > 3)

    {

        switch (path.Substring(path.Length - 3).ToLower())

        {

            case "jpg":

            case "bmp":

            case "gif":

                strImgPath.Add(path);

                break;

        }

    }

}

 

List<ScfElement> item = new List<ScfElement>();

 

for (int i = 0; i < strImgPath.Count; i++)

{

    FileInfo fi = new FileInfo(strImgPath[i]);

    Bitmap bmp = new Bitmap(fi.FullName);

    PageNo = i + 1;

    PicNo = 10000 + i + 1;

 

    bmp = new Bitmap(bmp, 240, (int)(240 * ((float)bmp.Height / bmp.Width)));

    YFGadget.AddContent(PicNo, ImageContentTransforms.ReduceColorDepth, bmp);  // | ImageContentTransforms.KeepAspectRatio| ImageContentTransforms.KeepAspectRatio    

 

    ScfElement content = Scf.Content(

        PageNo,

        fi.Name,

        200,

        Scf.Img(PicNo, ScfAlign.Center, ScfImageFit.Native, fi.Name),

        Scf.Txt(ScfAlign.Center, false, Color.Black, "", "<<   " + PageNo.ToString() + "/" + strImgPath.Count.ToString() + "   >>"),

        Scf.Btn(DeviceButton.Left, "", PageNo - 1 == 0 ? strImgPath.Count : PageNo - 1),

        Scf.Btn(DeviceButton.Right, "", PageNo + 1 > strImgPath.Count ? 1 : PageNo + 1),

        Scf.Btn(DeviceButton.Back, "", 100)

        );

 

    item.Add(Scf.Item(PageNo, fi.Name));

    YFGadget.AddContent(content);

    bmp.Dispose();

}

 

YFGadget.AddContent(Scf.Menu(

   100,

   "Main Menu",

    ScfSelectAction.Target,

    item.ToArray()

  ));

 

YFGadget.AddContent(Scf.Menu(

    200,

    "Right Menu",

     ScfSelectAction.Target,

     Scf.Item(100, "主菜单")

   ));

 

由于SDK提供了相关SCF操作函数,所以我们就没有必要写原始的XML格式的文件了。

 

OK,由于网上已有一些详细介绍Gadget编写的文章,所以我这里也就不啰嗦了。如有必要,可以给我留言,我们可以进一步交流Gadget编写技巧。

相关文章
|
7月前
|
Linux Android开发
嵌入式linux中Framebuffer 驱动程序框架分析
嵌入式linux中Framebuffer 驱动程序框架分析
70 0
|
Windows
23、Windows派遣函数(1)-Windows驱动开发详解笔记,IRP
驱动程序的主要功能是负责处理I/O请求,其中大部分I/O请求是在派遣函数中处理的。用户模式下所有对驱动程序的I/O请求,全部由操作系统转化为一个叫做IRP的数据结构,不同的IRP数据会被“派遣”到不同的派遣函数(Dispatch Function)中。
885 0
|
JavaScript 物联网 芯片
AliOS Things 硬件抽象层(HAL)对接系列2 — SPI driver porting
HAL层(Hardware abstraction layer) 的目的是为了屏蔽底层不同芯片平台的差异,从而使驱动层上面的软件不会随芯片平台而改变。AliOS Things定义了全面的HAL抽象层,这个系列主要介绍AliOS ThingsHAL层与不同芯片平台对接的poring要点,并举例说明。
2961 0
|
JavaScript 物联网 芯片
AliOS Things 硬件抽象层(HAL)对接系列3 — I2C driver porting
HAL层(Hardware abstraction layer) 的目的是为了屏蔽底层不同芯片平台的差异,从而使驱动层上面的软件不会随芯片平台而改变。AliOS Things定义了全面的HAL抽象层,这个系列主要介绍AliOS ThingsHAL层与不同芯片平台对接的poring要点,并举例说明。
3327 0
|
物联网 中间件
AliOS Things 使用HAL库的USB_DEVICE MSC调用SPI W25Q128
AliOS Things的USB_DEVICE MSC的SPI W25Q128实现
1137 0
SideShow Gadget开发[2]
开发常规Gadget理论上不拘于什么开发语言,只要能输出符合SCF格式的数据流即可。不过这里还是推荐使用C#(或基于.NET开发平台开发语言),可以直接引用相关开发库,非常简单的生成符合SCF格式的界面要素
582 0
|
JavaScript 物联网 芯片
AliOS Things 硬件抽象层(HAL)对接系列1 — GPIO driver porting
HAL层(Hardware abstraction layer 硬件抽象层) 的目的是为了屏蔽底层不同芯片平台的差异,从而使驱动层上面的软件不会随芯片平台而改变。AliOS Things定义了全面的HAL抽象层,这个系列主要介绍AliOS ThingsHAL层与不同芯片平台对接的poring要点,并举例说明。
3627 0
|
Linux Go 网络安全
嵌入式Linux USB WIFI驱动的移植
硬件平台:飞思卡尔MX258开发板 操作系统:Linux2.6.31 WIFI:    RT2860 USB WIFI模组 交叉编译环境:gcc version 4.1.2   调试步骤: 第一步:测试USB HOST接口 在menuconfig中将USB HOST设置为内核模式: ...
1701 0
WinXP下USB驱动开发(二)
2.3.       USB四种传输模式 2.3.1.  批量传输 批量传输是一种可靠的单向传输,但延迟没有保证,它尽量利用可以利用的带宽来完成传输,适合数据量比较大的传输。
970 0