博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
开源跨平台移动项目Ngui【视图与布局系统】
阅读量:6223 次
发布时间:2019-06-21

本文共 3077 字,大约阅读时间需要 10 分钟。

Ngui简介

这是一个GUI的排版显示引擎和跨平台的GUI应用程序开发框架,基于NodeJS/OpenGL,这也是第一个在移动端Android/iOS融合NodeJS的前端GUI项目,至此JavaScript成为了真正意义上前后端通吃的语言。

Ngui的目标:在此基础上开发GUI应用程序可拥有开发WEB应用般简单与速度同时兼顾Native应用程序的性能与体验。

视图View

在上一篇中我已经为大家讲了,今天我就来介绍ngui的核心部分(视图与布局)。

gui核心部件派生为。

用它来描述屏幕上所有可见的元素,它是所有视图的基础类型它也是事件的响应者,这些事件由硬件以及操作系统触发。详细的API文档讲大家去查阅。

下面是ngui现在提供的所有继承关系图:

注:带*号的为抽象类型或协议没有构造函数

  • *
    • *
  • *
    • *
      • *
            • <>
        • <>
              • <>
      • <>

看到这个继承关系大家是不是觉得有点复杂了,其实这要与浏览器比那真是小巫见大巫,当然那并不是我想要的,这一切都是为了效率。当然为了效率在功能上肯定是要做裁剪的,鱼和熊掌不可兼得。

有这么多视图它到底能为我们做什么呢?

视图在广义功能上划分有两类:

  • 非布局视图(非)
  • 布局视图()

非布局视图

顾名思义非布局视图就是那种不带布局功能的视图,就是你把它的位置固定后,它是不会再受到任何其它视图元素有影响,除非你再次更改它的位置translate属性。这种是最快的,因为不需要进行布局计算。

现在ngui提供的非布局视图有两个:

关于这两个视图的具体API接口说明请大家查阅文档,但在这里特别要说明的是transform,也就是矩阵变换。

矩阵变换是GUI绘图系统里的一个重要概念,transform用一个Matrix来描述绘图元素点线或面在屏幕上的实际位置与形状,这个矩阵通常由一组3x34x4向量组成,3x3为2d矩阵4x4为3d矩阵,在上使用的是一个裁剪过的3x2的2d矩阵所它暂时不支持3d中的z轴,以后的版本中可以会所变化。

中的transform属性并没有直接暴露而是换成了一组属性:

  • x
  • y
  • scaleX
  • scaleY
  • rotateZ
  • skewX
  • skewY

你可以通过matrix属性得到这个矩阵但它是只读的,只能通过xy这个方式对它进行设置。

调用final_matrix()函数得到的是父视图的final_matrix与当前视图的matrix乘积。对这就是这个视图在屏幕是的真实位置,确切的讲是这个.origin在屏幕上的确切位置,因为严谨的说一张图片或一个矩形在屏幕上是由4个点组成的一个面。

注意:

频繁的交替设置transform与调用matrix/finalMatrix会带来不必要的性能消耗,ngui的渲染逻辑是在渲染画面前不对任何视图属性设置做额外的计算只做存储并该标记属性的改变,等待准备渲染前才做统一的计算。当一个视图的transform改变时如果这时你要获取matrixfinalMatrix那么直接返回matrixfinalMatrix那一定是不正确的,幸好系统会做检测当发生了改变你要强取些值会提前对这些值做运算,返回一个正确的值给你,但如果你频繁的设置与获取,那就会频繁的做些运算。并且这只仅限于非布局视图,在布局视图上这样做并不会返回正确的值参见

布局视图

布局视图按可放置内容划分有三类:

Div

从API文档上看见只有一个属性contentAlign, 那么这里重点讲述就是这个属性,因为它是与浏览器完全不相同有的地方,至于基础类型大家可以参与API文档会有详细说明,注意padding这个属性在ngui里是没有的,因为这个导致系统复杂性上升,但以后要不要加待定。

ngui中并没有自己单独的浮动方式这个属性。但能设置它的contentAlign对它的内容对齐方式做出更改,这个属性可选的值有4个,默认为left左对齐

  • left
  • right
  • top
  • bottom

这其实很好理解 :

  • leftright为水平布局,内容对齐方式从左到右或从右到左排列,溢出往下换行。
  • topbottom为垂直布局,内容对齐方式从上到下或从下到上排列,溢出往右换列。

需要注意的是它的内容必须为类型否则这个属性并不会对它产生任何的效果,如果它内部出现了或那么与的出现不会对的内容布局造成任何影响,因为会忽略非内容的排版处理,同理一个或出现在非排版布局视图内部那它的位置与使用非布局视图没有区别。

Hybrid

与一样它也只有一个属性textAlign但它可以对任何内容做排版处理这当然也包括与。

与的区别的内容方式的不同,把它的所有内容都当成文本进行处理。它的可选有6个,默认为left

  • left
  • right
  • center
  • left_reverse
  • right_reverse
  • center_reverse

left right center 很好理解

left_reverse right_reverse center_reverse 是在对齐的基础上将内容颠倒排列,

如:对Ngui进行颠倒排版会变成这样

left_reverse center_reverse right_reverse
SJodacovA SJodacovA SJodacovA

Span,TextNode,Text

  • 并没有显示实体,也就是说它并不会在屏幕上显示任何可见的东西,它的存在只为是为了设置嵌套的视图属性,因为以上的属性都能被它的子所继承,这也是ngui中唯具有继承性质属性的视图。

  • 为的子类型,但它有实体它也是个叶子视图,也就是它不能再存在子视图。

  • 继承于与一样也是叶子视图不能存在子视图

Indep

独立的,相当于html-css中的绝对定位,它存在于与内部时,会进行独立排版,不会影响其它兄弟视图的排版位置。

Limit,IndepLimit

限制的盒子,minWidth, maxWidth,minHeight,maxHeight,这些属性能限制盒子的尺寸,这与html中的限制很相似。

Root

一个应用程序只能是唯一的也是必须的

Examples

最后为大家写一段代码实际运行一下

import {     GUIApplication: App, Root,    Div,     Indep,    Hybrid,     Span,    TextNode,} from 'ngui'new App().start(    
Hello
Ngui!
Hello Ngui!
)复制代码

下面是iphone6的运行效果:

下面是`iphone6`的运行效果

下面是Google nexus6的运行效果:

下面是`Google nexus6`的运行效果


就说到这里吧,已经累的不行了,下一篇为大家讲动作系统。

谢谢大家,未完待续~

转载于:https://juejin.im/post/5a159b9b5188254d2b6dc880

你可能感兴趣的文章
[家里蹲大学数学杂志]第248期东北师范大学2013年数学分析考研试题
查看>>
JAVA数组的定义及用法
查看>>
(转)winform安装项目、安装包的制作、部署
查看>>
C# WinForm 拖动无边框窗体 改变无边框窗体尺寸
查看>>
C++赋值函数详解
查看>>
删除vector中的偶数元素,删除list中的奇数元素
查看>>
循环-11. 水仙花数(20)
查看>>
奇偶校验算法
查看>>
boost:库program_options--第一篇
查看>>
分享最新的博客到LinkedIn Timeline
查看>>
MySQL主从架构之Master-Master互为主备
查看>>
discuz mysqli_connect() 不支持 advice_mysqli_connect
查看>>
KMP算法详解 --- 彻头彻尾理解KMP算法
查看>>
细嗅Promise
查看>>
Jquery中$与$.fn的差别
查看>>
MongoDB入门简单介绍
查看>>
Mining 任务分类
查看>>
HTML常见元素集锦
查看>>
[JQuery]用InsertAfter实现图片走马灯展示效果
查看>>
C实现通用数据结构--单链表
查看>>