zoukankan      html  css  js  c++  java
  • NODE-WEBKIT教程(5)NATIVE UI API 之FRAMELESS WINDOW

    /玄魂

     原文链接:http://www.xuanhun521.com/Blog/2014/4/15/node-webkit%E6%95%99%E7%A8%8B5native-ui-api-%E4%B9%8Bframeless-window

    前言

    几个月前,要开发一个简易的展示应用,要求支持离线播放(桌面应用)和在线播放(web应用)。

    当时第一想到的是flex,同一套代码(或者只需少量的更改)就可以同时运行在桌面和浏览器上。由于很多展现效果要全新开发,我想到了impress.js(https://github.com/bartaz/impress.js/)。如果选择impress.js,就意味着要将html5作为桌面应用,当时想到要封装webkit,但是本人对这方面也不是很熟悉,时间也很有限,就又沿着这个方向搜索,找到了node-webkit(https://github.com/rogerwang/node-webkit)

    node-webkit解决了我通过htmljs来编写桌面应用的难题

    至于node-webkit的定义,按照作者的说法:

     基于node.jschromium的应用程序实时运行环境,可运行通过HTML(5)CSS(3)Javascript来编写的本地应用程序。node.jswebkit的结合体,webkit提供DOM操作,node.js提供本地化操作;且将二者的context完全整合,可在HTML代码中直接使用node.jsAPI

    5.1  Frameless window 概述

    Frameless window,是没有操作系统默认样式的边框的窗口,也就意味着最大、最小和关闭按钮也访问不到,同时默认情况下窗口不能被拖拽。

    node webkit学习(2)基本结构和配置(http://www.xuanhun521.com/Blog/2014/4/10/node-webkit%E5%AD%A6%E4%B9%A02%E5%9F%BA%E6%9C%AC%E7%BB%93%E6%9E%84%E5%92%8C%E9%85%8D%E7%BD%AE)一文中,介绍frame属性时,给出了一个简单示例,本篇文章以该示例为基础进行扩展。

    Frameless window的使用场景,通常是我们需要自定义标题栏,窗口边框样式和按钮的时候。

    首先创建示例程序文件,framelessDemo.htmlpackage.json

    framelessDemo.html代码如下:

    <html>

    <head>

        <title>frame less windowdemo</title>

        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

    </head>

    <body >

        <h1>frameless window 测试</h1>

        <script>

        var gui = require('nw.gui');

        </script> 

    </body>

    </html>

    package.json内容如下:

    {

      "name": "framelessWindow-demo",

      "main": "framelessDemo.html",

      "nodejs":true,

       "window": {

        "title": " framelessWindow-demo ",

        "toolbar": true, 

        "width": 800, 

        "height": 600,

       "resizable":true,

       "show_in_taskbar":true,

       "frame":false,

       "kiosk":false

      },

      "webkit":{

      "plugin":true

      }

    }

    运行程序,效果如下:

    此时窗口无边框,无标题栏,不能拖拽。

    5.2 如何启用无边框窗口

    鄙视不标明出处的转载,更多相关内容,欢迎访问玄魂的博客www.xuanhun521.com

     

    注意package.jsonwindow的配置,将字段frame设置为false即可。

    {

      "window": {

        "frame": false

      }

    }

    5.3 窗口拖拽

    默认情况下,无框窗口是不可拖拽的,可以通过给body添加“-webkit-app-region: drag”样式,来启用拖拽。

    如果在body上设置了拖拽,需要在button上去除拖拽,否则按钮无法点击,添加如下样式:

      button {

               -webkit-app-region: no-drag;

           }

    如果你仅仅使用自定义titlebar组件,也需要设置在titlebar中的按钮no-drag

    5.4  窗口操作

    鄙视不标明出处的转载,更多相关内容,欢迎访问玄魂的博客www.xuanhun521.com

    在无框窗口中,我们仍然需要使用户能够进行最大、最小,关闭窗口等操作。

    首先我们可以使用javascript中的window对象来关闭窗口。

    因为node-webkitwindow对象,使用window api是我们的首选,详见:node-webkit学习(4)Native UI API windowhttp://www.xuanhun521.com/Blog/2014/4/14/node-webkit%E5%AD%A6%E4%B9%A04native-ui-api-%E4%B9%8Bwindow

    5.5 推荐demo

    demo地址:https://github.com/zcbenz/nw-sample-apps/tree/master/frameless-window

    这个示例演示了使用frameless window时,如何自定义实现所有标准窗口的功能。

    5.6 小结

    本文内容主要参考node-webkit的官方英文文档(https://github.com/rogerwang/node-webkit/wiki/Frameless-window)。

    下一篇文章,介绍menu

    鄙视不标明出处的转载,更多相关内容,欢迎访问玄魂的博客www.xuanhun521.com

    更多相关内容,欢迎访问玄魂的博客(更多node-webkit相关内容 http://www.xuanhun521.com/Blog/Tag/node-webkit)


    ps:nw.js,electron交流群 313717550 

     

  • 相关阅读:
    【译文】HTML5 Canvas的点击区域检测以及如何监听Canvas上各种图形的点击事件
    快速排序法精简理解
    数据结构--堆
    数据结构--哈希表
    数据结构--队列
    数据结构--栈
    数据结构--数组
    数据结构--链表
    算法的基本知识
    Arthas
  • 原文地址:https://www.cnblogs.com/xuanhun/p/3666461.html
Copyright © 2011-2022 走看看