过期罐头电脑论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3312|回复: 0
收起左侧

亲身 入手 开发Windows7 边侧栏小工具应用程序

[复制链接]
含恨饮砒霜 2012-7-18 16:21:05 | 显示全部楼层
Windows7的小工具不只 能美化桌面环境,而且还具备许多的特色功能,可以用它来查询天气、航班、信息、时间、股票......这些小工具给我们带来美好的体验的同时,也丰富了文娱 生活。那么,我们自己. 该如何开发这类美观适用 的小工具吗?下面笔者就以一个简易天气预告 程序的开发过程为例,与大家共享此类程序开发的方法和经历 。

   2012111220455276.jpg        
2012111220455276.jpg        



  工具/原料

  

  •   Windows Vista 或 Windows 7 操作系统



  •   HTML、CSS、JavaScript、XML





  主页面开发

  

  •   新建一个文件夹,取名为"MyWeather.Gadget",并在该文件夹下创建一个称号 为"WeatherReport.html"的网页文件,该文件将作为主页面被显示,其对应的HTML代码如下:


    我的天气小应用程序


       


      



      




       2012111220455276.jpg        


  •   在"MyWeather.Gadget"目录下创建一个称号 为"CSS"的新文件夹,并创建称号 为"MyWeather.css"的层叠款式 表文件,该文件将用于设置主页面"WeatherReport.html"的显示效果,其对应代码如下:
    body{ margin: 0; width: 134px; height:150px; border:1px solid #000000;
    font-weight: bold; font-size:small; background-color:White;
    vertical-align:top; text-align: center; font-size:14px;}
    #gadgetContent { margin: 0px; width: 130px; height:120px;vertical-align: middle;
    text-align: center; float:none; display:inline-block; }
    #mybackground{ height:150px; }
    #author{ font-size:15px; border-top:2px solid #45ff00; background-color:White;
    padding:0px; width:130px; height:30px; float:none;
      margin:2px 1px 1px 1px; position:relative; z-index:3; }

       2012111220455276.jpg        


  •   在"MyWeather.Gadget"目录下创建一个名为"js"的文件夹,并在该文件夹下创建一个称号 为"MyWeather.js"的脚本文件,该文件用于控制主页面文件"WeatherReport.html"的行为。其对应代码如下:
    var times =1; //1 代表 1分钟
    var shows = 10; //1 代表显示一天的预告 信息
    var ReceverString;
    var GadgetTime;
    function loadMian()
    {
    System.Gadget.visibilityChanged = checkVisibility;
    System.Gadget.onDock = Dock;
    System.Gadget.onUndock = unDock;
    }
    function SpecialRefresh() {
    loadMian();

      if (updateTimeInterval == "") times = 10 * 1000 * 10;
    else times = updateTimeInterval * 60 * 1000;
      GadgetTime = setTimeout("self.location.reload()", times);
    }
    function checkVisibility()
    {
    var isVisible = System.Gadget.visible;
      if (!isVisible)
    {
    clearTimeout(GadgetTime);
    }
    }
    function unDock() {}
    function Dock() {}

       2012111220455276.jpg        


  •   在"MyWeather.Gadget"目录下创建一个名为"gadget.xml"的文件,该文件用于描绘 整个小工具程序的框架,其对应代码如下:


    简易天气预告 程序
    http://jingyan.baidu.com/user/nuc/expList?type=1>

    1.0.1.0

      

      

    DIY易度空间 By ©feifeidown
    天气预告 实例程序,用于实时观测当地的天气状况  


      


      

    true



    full







       2012111220455276.jpg        


  •   制作三个称号 分别为"icon.png"、"dragicon.png"和"logo.png"的图形文件,拷贝到"MyWeather.Gadget"目录下。其中各个文件的尺寸如图[ghost win7纯净版]所示[win7旗舰版系统下载] 。


       2012111220455276.jpg        


  •   将"MyWeather.Gadget"文件夹拷贝到"%系统根目录%Program Files/Windows Sidebar/Gadgets/"目录下。注意:此步操作需要. 管理员权限。然后右击桌面,选择"小工具",在弹出的"百宝箱"界面当选 择"简易天气预告 程序"小工具,并拖动到桌面的任意位置,假如 一切顺利的话,界面应该如下图所示[win7旗舰版系统下载] 。


       2012111220455276.jpg        




  设置界面的开发

  

  •   在"MyWeather.Gadget"目录创建一个名为"settings.html"的文件,该文件用于显示"设置弹出对话框",其对应代码如下:
    Setting 设置窗体示例





    预告 天数:
    天预告 信息


    更新频率:
    分钟更新一次数据


    该设置将会被提交给主页面





       2012111220455276.jpg        


  •   为了实现"设置界面"与"程序主页面"之间的信息交流 ,需要. 编写脚本语言。在"js"目录下创建一个名为"settings.js"的脚本文件,其对应代码如下:
    function InitSettings()
    {
    var showDs=System.Gadget.Settings.read("ShowDays");
    var updateTs =System.Gadget.Settings.read("UpdateTimes");
    if (showDs != "") ShowDays.innerText = showDs;
    if (updateTs != "") UpdateTimes.innerText = updateTs;
      System.Gadget.onSettingsClosing = SettingsClosing;
    }
    function SettingsClosing(event)
    {
    if (event.closeAction == event.Action.commit)
    {
    saveSettings();
    }
    event.cancel = false; //关闭设置
    }
    function saveSettings()
    {
      var showDs = ShowDays.value;
    var updateTs = UpdateTimes.value;
      System.Gadget.Settings.write("ShowDays", showDs);
    System.Gadget.Settings.write("UpdateTimes", updateTs);
    }

       2012111220455276.jpg        


  •   修改"myWeather.js"文件,在其中加入与"设置页面"进行信息交流 的代码,在增加部分代码后其完整程序如下:
    var times =1; //1 代表 1分钟
    var shows = 10; //1 代表显示一天的预告 信息
    var ReceverString;
    var GadgetTime;
    function loadMian()
    {

    System.Gadget.visibilityChanged = checkVisibility;
    System.Gadget.onDock = Dock;
    System.Gadget.onUndock = unDock;


    //该句的设置将使“设置”按钮生效
    System.Gadget.settingsUI = "settings.html";
    System.Gadget.onSettingsClosed = settingsClosed;
    }
    function settingsClosed()
    {
    clearTimeout(GadgetTime);
    GadgetTime=setTimeout("self.location.reload();", 100);
    }
    function SpecialRefresh() {
    loadMian();
    var updateTimeInterval = System.Gadget.Settings.read("UpdateTimes");
    var showDaysForDisp = System.Gadget.Settings.read("ShowDays");
    var ifv = parent.document.getElementById("myiframe");
    var gc = parent.document.getElementById("gadgetContent");
      if (updateTimeInterval == "") times = 10 * 1000 * 10;
    else times = updateTimeInterval * 60 * 1000;
      if (showDaysForDisp != "")
    {
    if (showDaysForDisp < 1) showDaysForDisp = 1;
    if (showDaysForDisp >7) showDaysForDisp = 7;
    if (parseInt(showDaysForDisp,10) == 1) gc.style.overflow = "hidden";
    else { gc.style.overflow = "auto"; }
      shows = (showDaysForDisp - 1) * 102 + 120;
    }
    else
    {
    gc.style.overflow = "hidden";
    shows = (shows - 1) * 102 + 120;
    }
      ifv.style.height = parseInt(shows, 10);
    checkDockState();
    GadgetTime = setTimeout("self.location.reload()", times);
    }
    function checkVisibility()
    {
    var isVisible = System.Gadget.visible;

    if (!isVisible)
    {
    clearTimeout(GadgetTime);
    }
    }
    }
    function unDock() {}
    function Dock() {}


  •   将"MyWeather.Gadget"文件夹拷贝到"%系统根目录%Program Files/Windows Sidebar/Gadgets/"目录下。注意:此步操作需要. 管理员权限。然后右击桌面,选择"小工具",在弹出的"百宝箱"界面当选 择"简易天气预告 程序"小工具,并拖动到桌面的任意位置,假如 一切顺利的话,点击小工具当中的"选项"按钮,界面应该如下图所示[win7旗舰版系统下载] 。


       2012111220455276.jpg        




  "飞出窗体"的设计

  

  •   在"MyWeather.Gadget"目录下创建一个名为"Flyout.html"的文件,该文件用于实现"飞出窗体"的显示,其对应代码如下:







      

    *简易天气预告 小工具*





       2012111220455276.jpg        


  •   修改主页面的代码,加入脚本实现对"飞出窗体"的显示控制。其主页面的代码在修改后为:


    我的天气小应用程序


      




      



      

    *By feifeidown*



       2012111220455276.jpg        


  •   修改"myWeather.js"脚本文件,加入对"飞出窗体"的控件部分,完成后其代码如下:
    var times =1; //1 代表 1分钟
    var shows = 10; //1 代表显示一天的预告 信息
    var ReceverString;
    var GadgetTime;
    function loadMian()
    {
    System.Gadget.visibilityChanged = checkVisibility;
    System.Gadget.onDock = Dock;
    System.Gadget.onUndock = unDock;
    //该句的设置将使“设置”按钮生效
    System.Gadget.settingsUI = "settings.html";
    System.Gadget.onSettingsClosed = settingsClosed;
      System.Gadget.Flyout.file = "Flyout.html";
    System.Gadget.Flyout.onHide = FOonHide;
    System.Gadget.Flyout.onShow = FOonShow;
    // System.Gadget.Flyout.show = true; }
    function settingsClosed()
    {
    clearTimeout(GadgetTime);
    GadgetTime=setTimeout("self.location.reload();", 100);
    }
    function SpecialRefresh() {
    loadMian();
    var updateTimeInterval = System.Gadget.Settings.read("UpdateTimes");
    var showDaysForDisp = System.Gadget.Settings.read("ShowDays");
    var ifv = parent.document.getElementById("myiframe");
    var gc = parent.document.getElementById("gadgetContent");
      if (updateTimeInterval == "") times = 10 * 1000 * 10;
    else times = updateTimeInterval * 60 * 1000;
      if (showDaysForDisp != "")
    {
    if (showDaysForDisp < 1) showDaysForDisp = 1;
    if (showDaysForDisp >7) showDaysForDisp = 7;
    if (parseInt(showDaysForDisp,10) == 1) gc.style.overflow = "hidden";
    else { gc.style.overflow = "auto"; }
      shows = (showDaysForDisp - 1) * 102 + 120;
    }
    else
    {
    gc.style.overflow = "hidden";
    shows = (shows - 1) * 102 + 120;
    }
      ifv.style.height = parseInt(shows, 10);
    checkDockState();
    GadgetTime = setTimeout("self.location.reload()", times);
    }
    function checkVisibility()
    {
    var isVisible = System.Gadget.visible;

    if (!isVisible)
    {
    clearTimeout(GadgetTime);
    }
    }
    function unDock() {}
    function Dock() {}
    function FOonHide()
    {
    GadgetTime = setTimeout("self.location.reload()", 2000);
    }
    function FOonShow()
    {
    if (System.Gadget.docked) {
    System.Gadget.Flyout.Document.parentWindow.weather_fo.style.backgroundColor = "Red";
    }
    else
    {
    System.Gadget.Flyout.Document.parentWindow.weather_fo.style.backgroundColor = "White";
    }
    }
    function showFlyout()
    {

    stopTimer();
    System.Gadget.Flyout.show = true;
    }
    function stopTimer() {
    if (GadgetTime) {
    clearInterval(GadgetTime);
    }
    }


  •   将"MyWeather.Gadget"文件夹拷贝到"%系统根目录%Program Files/Windows Sidebar/Gadgets/"目录下。注意:此步操作需要. 管理员权限。然后右击桌面,选择"小工具",在弹出的"百宝箱"界面当选 择"简易天气预告 程序"小工具,并拖动到桌面的任意位置,假如 一切顺利的话,点击小工具当中的"选项"按钮,然后双击小工具界面下方的文本,假如 一切顺利,界面应该如下图所示[win7旗舰版系统下载] 。


       2012111220455276.jpg        




  美化窗体

  

  •   创建称号 分别为"background1.png"、"background2.png"、"FObg1.png"和"FObg2.png"的图片文件,并拷贝到images文件夹目录下,其大小如图[ghost win7纯净版]如下,用于实现小工具的自定义皮肤效果。


       2012111220455276.jpg        


  •   修心"Myweather.js"脚本文件,加入对皮肤的设置控制代码,在加入部分代码后其最终完整代码如下:
    var times =1; //1 代表 1分钟
    var shows = 10; //1 代表显示一天的预告 信息
    var ReceverString;
    var GadgetTime;
    function loadMian()
    {

    System.Gadget.visibilityChanged = checkVisibility;
    System.Gadget.onDock = Dock;
    System.Gadget.onUndock = unDock;

    //该句的设置将使“设置”按钮生效
    System.Gadget.settingsUI = "settings.html";
    System.Gadget.onSettingsClosed = settingsClosed;
      System.Gadget.Flyout.file = "Flyout.html";
    System.Gadget.Flyout.onHide = FOonHide;
    System.Gadget.Flyout.onShow = FOonShow;
    // System.Gadget.Flyout.show = true;
    }
    function settingsClosed()
    {
    clearTimeout(GadgetTime);
    GadgetTime=setTimeout("self.location.reload();", 100);
    }
    function SpecialRefresh() {
    loadMian();
    var updateTimeInterval = System.Gadget.Settings.read("UpdateTimes");
    var showDaysForDisp = System.Gadget.Settings.read("ShowDays");
    var ifv = parent.document.getElementById("myiframe");
    var gc = parent.document.getElementById("gadgetContent");
      if (updateTimeInterval == "") times = 10 * 1000 * 10;
    else times = updateTimeInterval * 60 * 1000;
      if (showDaysForDisp != "")
    {
    if (showDaysForDisp < 1) showDaysForDisp = 1;
    if (showDaysForDisp >7) showDaysForDisp = 7;
    if (parseInt(showDaysForDisp,10) == 1) gc.style.overflow = "hidden";
    else { gc.style.overflow = "auto"; }
      shows = (showDaysForDisp - 1) * 102 + 120;
    }
    else
    {
    gc.style.overflow = "hidden";
    shows = (shows - 1) * 102 + 120;
    }
      ifv.style.height = parseInt(shows, 10);
    checkDockState();
    GadgetTime = setTimeout("self.location.reload()", times);
    }
    function checkVisibility()
    {
    var isVisible = System.Gadget.visible;

    if (!isVisible)
    {
    clearTimeout(GadgetTime);
    }
    }
    function checkDockState()
    {
    if (System.Gadget.docked) { Dock(); }
    else { unDock(); }
    }
    function unDock() {
    var mybground = document.getElementById("myBackground");
    mybground.src = "url(images/background2.png)";
    author.style.color = "gray";
    }
    function Dock() {
    var mybground = document.getElementById("myBackground");
    mybground.src = "url(images/background1.png)";
    author.style.color = "red";
    }
    function FOonHide()
    {
    GadgetTime = setTimeout("self.location.reload()", 2000);
    }
    function FOonShow()
    {
    if (System.Gadget.docked) {
    System.Gadget.Flyout.Document.parentWindow.weather_fo.style.backgroundColor = "Red";
    }
    else
    {
    System.Gadget.Flyout.Document.parentWindow.weather_fo.style.backgroundColor = "White";
    }
    }
    function showFlyout()
    {
    stopTimer();
    System.Gadget.Flyout.show = true;
    }
    function stopTimer() {
    if (GadgetTime) {
    clearInterval(GadgetTime);
    }
    }
    function changeThema() {
      if (!System.Gadget.docked) {
    var pp = document.getElementById("FOauthor");
    var dd = document.getElementById("weather_fo");
    dd.style.backgroundImage = "url(images/FObg1.png)";
    pp.style.color = "Red";
    pp.style.backgroundColor = "Orange";
    }
    else {
    var pp = document.getElementById("FOauthor");
    var dd = document.getElementById("weather_fo");
    dd.style.backgroundImage = "url(images/FObg2.png)";
    pp.style.color = "Gray";
    pp.style.backgroundColor = "White";
      }
    }


  •   将"MyWeather.Gadget"文件夹拷贝到"%系统根目录%Program Files/Windows Sidebar/Gadgets/"目录下。注意:此步操作需要. 管理员权限。然后右击桌面,选择"小工具",在弹出的"百宝箱"界面当选 择"简易天气预告 程序"小工具,并拖动到桌面的任意位置,假如 一切顺利的话,点击小工具当中的"选项"按钮,然后双击"尺寸"按钮,假如 一切顺利,界面应该如下图所示[win7旗舰版系统下载] 。


       2012111220455276.jpg        
    2012111220455276.jpg        




  注意事项

  

  •   安装或复制文件时需要. 管理员权限



  •   设计Gadget应恪守 的原则:在有效的空间内保持其有效性;



  •   还有一个要注意的地方,小工具的页面和文件必须是utf-8编码字符集,假如 是gb2312可能会出现乱码


您需要登录后才可以回帖 登录 | 注册

本版积分规则

一键重装系统|雨人系统下载|联系我们|网站地图|过期罐头电脑论坛

GMT+8, 2025-1-15 17:44 , Processed in 0.039759 second(s), 28 queries .

官方免责声明:本站内容来自网友和互联网.若侵犯到您的版权.请致信联系,我们将第一时间删除相关内容!

Powered by Discuz!

专注于win7_win10_win11系统下载装机

© 2010-2023 GQGTPC.Com

快速回复 返回顶部 返回列表