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. 重构手法之Split Temporary Variable(分解临时变量)

    返回总目录 本小节目录 Split Temporary Variable(分解临时变量) Remove Assignments to Parameters(移除对参数的赋值) 6.6Split Tem ...

  2. Java多线程学习之ThreadLocal源码分析

    0.概述 ThreadLocal,即线程本地变量,是一个以ThreadLocal对象为键.任意对象为值的存储结构.它可以将变量绑定到特定的线程上,使每个线程都拥有改变量的一个拷贝,各线程相同变量间互不 ...

  3. django作业练习

    ---权限管理系统 要求: 1,登陆: a,装饰器判断用户是否已经登陆 b,用户密码使用md5发送 2,注册 a,检测用户是否已经存在,onblur+ajax光标跳出输入框时(使用ajax) 3,注销 ...

  4. 老男孩Python全栈开发(92天全)视频教程 自学笔记01

    day1课程目录: 开课介绍(1) 开课介绍(2) 开课介绍(3) 电脑简史(1) 电脑简史(2) 计算机结构 day1课程内容梳理: 导师介绍: Alex Li(金角大王):买了一辆特斯拉,喜欢姑娘 ...

  5. Java精选笔试题

    合抱之木,生于毫末:九层之台,起于垒土:千里之行:始于足下.赶快测测你的Java基础知识掌握的如何? 1,下列说法正确的是() A.一个文件里可以同时存在两个public修饰的类 B.构造函数可以被重 ...

  6. Dom模型

    1.dom之对象分类 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...

  7. propertychange 不起作用

    兼容性问题.将$("#systemLogSettings td[name='nMaxFileSize'] input").on("input propertychange ...

  8. 深入理解ES6之——JS类的相关知识

    基本的类声明 类声明以class关键字开始,其后是类的名称:剩余部分的语法看起来像对象字面量中的方法简写,并且在方法之间不需要使用逗号. class Person { //等价于prototype的构 ...

  9. ubuntu实时显示网速cpu占用和内存占用率

    ubuntu实时显示网速cpu占用和内存占用率 大家在使用ubuntu的时候,有没有想让它实时显示网速,内存占用率,或者cpu占用率呢?现在我就教大家怎么实现,就像下面这样 1. 添加indicato ...

  10. Linux EXT 文件系统 详解

    上几章我们讲到了Linux启动的一些问题,接下来我们来看一下硬盘分割和EXT格式文件系统的问题.前面提到了分区表的问题,分区表位于MBR, 占用64个字节.所谓的硬盘分区也就是对硬盘进行规划,填写分区 ...