NanUI文档目录

使用网页来设计整个窗口

创建NanUI应用的方法本文不再阐述,具体方法请参看文章目录里的相关文章。本文将介绍NanUI的核心功能,用一张网页铺满整个窗体区域,并将讲述如何使用CSS和HTML来实现对窗体的拖动、最大化、最小化、关闭等操作。

如图所示的界面,整个窗体的样式都是由HTML和CSS等前端技术来呈现的。具体的HTML/CSS/JS代码本文不详细描述,因为这些和NanUI的关联不大,根据实际项目的需要,您可以为您的软件界面设计出更棒的效果。

在示例界面中,我们将主要介绍系统命令菜单部分的最小化、最大化和关闭按钮,以及界面左侧红色的可用作拖动窗体的纵向标题栏的实现。

用前端技术来解析,左侧纵向标题栏其本质是一条宽度固定,高度100%的DIV;命令区域内的最小化、最大化和关闭按钮其本质是三个SPAN标签内嵌套了三个不同的FontAwsome的图标。下面的内容将介绍它们是如何实现对承载窗体状态改变的。

如何通过拖拽HTML元素来移动窗体位置

如果您需要实现类似示例中拖动左侧红色区域标题栏来改变窗体位置的功能,那么在该元素对应的CSS中只需指定该元素所在区域的-webkit-app-region属性值为drag即可实现:

.some-class{
-webkit-app-region:drag;
}

指定此样式后,只要鼠标指针在该样式作用的区域内执行拖拽操作,那么NanUI的承载窗体的位置将随鼠标的拖动而发生改变。

但在设计界面时,如果您希望在可拖动元素区域内的某些区域不接收拖动信号,那么只需要将-webkit-app-region属性值改为no-drag即可。

例如示例中,三个系统命令按钮实际上是包括在一个DIV元素内,同时这个DIV设置了-webkit-app-region属性值为drag,这时您会发现,拖动这个DIV所在区域(包括三个命令按钮的区域)时窗体都实现了移动,但是这也阻断了这个区域内的其他鼠标操作,包括三个命令按钮的鼠标点击操作。这明显不是所期望的效果。如下,该区域的HTML代码为:

<div class="app-sys-command-container">
<ul class="sys-commands">
<li n-ui-command="minimize">
<i class="fa fa-window-minimize"></i>
</li>
<li n-ui-command="maximize">
<i class="fa fa-window-maximize"></i>
</li>
<li n-ui-command="close">
<i class="fa fa-close"></i>
</li>
</ul>
</div>

在css样式.app-sys-command-container中设置了-webkit-app-region属性值为drag,这导致了ul.sys-commands区域也呈现可拖动的状态。为了避免这个区域被默认的拖动事件影响到其他事件的相应,那么就需要设置.sys-commands的样式-webkit-app-region属性值为no-drag,那么这部分区域将不再相应窗体拖动的事件。这部分的CSS代码为:

.demo-app > content > .app-sys-command-container {
...
-webkit-app-region: drag;
...
} .demo-app > content > .app-sys-command-container > .sys-commands {
...
-webkit-app-region: no-drag;
...
}

这样,您就可以灵活的控制可拖动来改变窗体位置的区域了。

如何通过HTML元素来执行窗体的最大化/最小化/关闭操作

在上面的html代码片段中,展示了示例程序的三个系统命令按钮的实现方式:

<div class="app-sys-command-container">
<ul class="sys-commands">
<li n-ui-command="minimize">
<i class="fa fa-window-minimize"></i>
</li>
<li n-ui-command="maximize">
<i class="fa fa-window-maximize"></i>
</li>
<li n-ui-command="close">
<i class="fa fa-close"></i>
</li>
</ul>
</div>

其中的i标签内,可以看到不常见的html属性n-ui-command,这一属性是NanUI用来标注按钮行为的专用属性,通过其属性值minimize/maximize/close不难看出,通过点击具备这一专用属性的标签,就能够实现窗体对应的最小化/最大化/关闭操作。

特别需要指出的,在示例窗体中点击最大化按钮后可以看到,最大化按钮的图标从最大化改变成了还原的样式,这是通过使用Javascript监测窗体事件来实现的。

如同上面介绍的专用属性,NanUI还内置了一些专用的事件。通过监听这些事件来实现一些特殊的功能,例如上面所说的最大化窗体时改变系统按钮的图标,又或者是窗体市区焦点时改变标题栏的颜色等。

NanUI 窗体专用事件

目前NanUI实现的专用事件有以下三个:

  • hoststatechange: 窗体状态(最大化、最小化、还原)发生改变时触发。
  • hostactivestate: 窗体获得或丢失焦点时触发。
  • hostsizechange: 窗体大小改变时触发。

通过监听这些事件,您就可以根据需求来实现一些特定的效果。如示例项目中,使用了jQuery来监听这三个专用事件:

$(function () {
//窗口状态改变
$(window).on("hoststatechange", function (e) {
console.log(e.detail);
$("#label-form-state").text(e.detail.stateName); }); //窗口激活状态改变
$(window).on("hostactivestate", function (e) {
console.log(e.detail);
$("#label-activated-state").text(e.detail.stateName); if (e.detail) {
if (e.detail.state === 1) {
$("html").addClass("app-active");
}
else {
$("html").removeClass("app-active");
}
}
});
//窗口尺寸改变
$(window).on("hostsizechange", function (e) {
console.log(e.detail);
$("#label-size-state").text(`width:${e.detail.width} height:${e.detail.height}`); }); });

上述代码的具体效果,可以自行对示例程序进行调试来查看效果。

内置Javascript对象 - NanUI

NanUI除了实现了上述的专用html属性n-ui-command和三个专用事件外,在Javascript全局环境中还内置了一个专用对象NanUI,通过该对象您可以查询当前NanUI和CEF的版本号,通过hostWindow中的方法来获取当前窗体的状态值,执行最大化、最小化和关闭操作。

示例源码

git clone https://github.com/NetDimension/NanUI-Examples-03-Design-Your-Form-With-Html.git

社群和帮助

GitHub

https://github.com/NetDimension/NanUI/

交流群QQ群

521854872

赞助作者

如果你喜欢我的工作,并且希望NanUI持续的发展,请对NanUI项目进行捐助以此来鼓励和支持我继续NanUI的开发工作。你可以使用微信或者支付宝来扫描下面的二维码进行捐助。

NanUI文档 - 使用网页来设计整个窗口的更多相关文章

  1. NanUI文档 - 开始使用NanUI

    NanUI文档目录 NanUI简介 开始使用NanUI 打包并使用内嵌式的HTML/CSS/JS资源 使用网页来设计整个窗口 如何实现C#与Javascript相互掉用(待更新...) 如何处理Nan ...

  2. NanUI文档 - 打包并使用内嵌式的HTML/CSS/JS资源

    NanUI文档目录 NanUI简介 开始使用NanUI 打包并使用内嵌式的HTML/CSS/JS资源 使用网页来设计整个窗口 如何实现C#与Javascript相互掉用(待更新...) 如何处理Nan ...

  3. NanUI文档 - 如何实现C#与Javascript的相互通信

    NanUI文档目录 NanUI简介 开始使用NanUI 打包并使用内嵌式的HTML/CSS/JS资源 使用网页来设计整个窗口 如何实现C#与Javascript的相互通信 如何处理NanUI中的下载过 ...

  4. 在Winform框架的多文档界面中实现双击子窗口单独弹出或拖出及拽回的处理

    在基于DevExpress的多文档窗口界面中,我们一般使用XtraTabbedMdiManager来管理多文档窗口的一些特性,如顶部菜单,页面的关闭按钮处理,以及一些特殊的设置,本篇随笔介绍这些特点, ...

  5. Java文档上传问题设计

    近期公司让做一个文档上传的功能,功能描写叙述大概是这样子滴 书籍名称.书籍定价.书籍封面图片(须要上传).文档内容 (须要上传) .还有其它相关的描写叙述信息. 我的设计  表 A  包括以上字段 , ...

  6. 如何真正实现由文档驱动的API设计?

    前言 本文主要介绍了一种新的开发思路:通过反转开发顺序,直接从API文档中阅读代码.作者认为通过这种开发方式,你可以更清楚地知道文档表达出什么以及它应该如何实现. 如果单从API文档出发,由于信息量不 ...

  7. (转)如何真正实现由文档驱动的API设计?

    前言 本文主要介绍了一种新的开发思路:通过反转开发顺序,直接从API文档中阅读代码.作者认为通过这种开发方式,你可以更清楚地知道文档表达出什么以及它应该如何实现. 如果单从API文档出发,由于信息量不 ...

  8. SharePoint文档库,如何在新窗口打开中的文件

    默认情况下,点击文档库中的文件是在当前浏览器中打开的(如果你设置的是在客户端软件打开,则不符合本文情况).那么如果让他在新窗口中打开呢? 这里需要借助jQuery,关于如何将jQuery集成到Shar ...

  9. 【技术文档】《算法设计与分析导论》R.C.T.Lee等·第7章 动态规划

    由于种种原因(看这一章间隔的时间太长,弄不清动态规划.分治.递归是什么关系),导致这章内容看了三遍才基本看懂动态规划是什么.动态规划适合解决可分阶段的组合优化问题,但它又不同于贪心算法,动态规划所解决 ...

随机推荐

  1. C#中访问私有成员

    首先访问一个类的私有成员不是什么好做法.大家都知道私有成员在外部是不能被访问的.一个类中会存在很多私有成员:如私有字段.私有属性.私有方法.对于私有成员造访,可以套用下面这种非常好的方式去解决. pr ...

  2. linux下curl的地址使用双引号引用的原因

    只知道这么使用,加上双引号,原因不太清楚 原因在于加上双引号可以防止转义,在linux中使用&会使进程后台运行,必须对&进行转义,加反斜杠的方式比较麻烦,故使用双引号模式最方便.

  3. 【转】python XML 操作总结(创建、保存和删除,支持utf-8和gb2312)

    原文地址:http://hi.baidu.com/tbjmnvbagkfgike/item/6743ab10af43bb24f6625cc5 最近写程序需要用到xml操作,看了看python.org上 ...

  4. 根据自己的博客数据统计国内IT人群

    装上百度统计有一段时间了,今天突然找出报表看看,发现一个很有意思的事情.访问来源TOP5依次是:北京,上海,深圳,杭州,广州 虽然大部分文章都是当时特别白的时候记录下来的遇到过的问题,但受众确实应该只 ...

  5. 实战Excel Add-in的三种玩法

    作者:陈希章 发表于 2017年11月26日 前言 这个系列文章应该有一阵子没有更新了,原因是一如既往的多,但是根本所在是我对于某些章节其实还没有完全想好怎么写,尤其是对于Office Add-in这 ...

  6. SSM框架下结合 log4j、slf4j打印日志

    首先加入log4j和slf4j的jar包 <!-- 日志处理 <!-- slf4j日志包--> <dependency> <groupId>org.slf4j ...

  7. 模板文件引入css样式文件

    引用路径问题:相对路径和绝对路径 相对路径:相对路口文件index.php设置 绝对路径:从虚拟主机站点目录开始设置 css样式文件引入图片,路径的设置 相对地址:相对css文件本身设置 ①模板文件 ...

  8. Web Api 2.0中使用Swagger生成Api文档的2个小Tips

    当Web Api 2.0使用OAuth2授权时,如何在Swagger中添加Authorization请求头? Swagger说明文档支持手动调用Api, 但是当Api使用OAuth2授权时,由于没有地 ...

  9. base64位加密解密

    1.base64位加密base64是用于传输8Bit字节代码,由上图的编码表可以知道,编码后的内容只包含这64个字符类型,所以称为base64编码 2.编码过程 : 首先将待编码的内容转换成8位二进制 ...

  10. mysql索引优化面试题

    曾经偷偷的面试了两个单位,都提到了Mysql的优化问题,所以以后要多多学习数据库的优化知识了.建设数据库的优化大概主要就是索引的优化了吧,因为我们不可能修改数据结构的情况下,提高数据库的查询效率似乎也 ...