漫谈GUI开发—各种平台UI开发概况

前言:

在看这边文章前,可以建议看下:图形界面操作系统发展史——计算机界面发展历史回顾

从CS到BS,现在的前端开发,其实也是GUI开发范畴。现今

各平台的UI开发概况

HTML&CSS,Winform&WPF,Universal Windows APP,JAVA GUI, Android,iOS……

不一而足,先让我们看看

JAVA GUI

我觉得java是最好学的语言。也是像我这种非科班出生的,踏入码农行业的敲门砖(看C c++ 学了一年,也就hello word,会写几个demo界面)。

做java开发,从AWT/Swing、SWT/JFace,这个有IBM的大佬总结,传送门:https://www.ibm.com/developerworks/cn/java/j-gui/

我觉得,无论是c还是java,还是 后面的hmlt ,UI开发 总可以借鉴基本的Swing Class 树

Object

*Component

Container

*JComponent

*AbstractButton

JButton

JMenuItem

JCheckBonMenuItem

JMenu

JRadioButonMenuItem

*JToggleButton

JCheckBox

JRadioButton

Box

Filler

JColorChooser

JComboBox

JDesktopIcon

JFileChooser

JInternalFrame

JLabel

JLayeredPane

JDesktopPane

JList

JMenuBar

JOptionPane

JPanel

JPopupMenu

JProgressBar

JRootPane

JScrollBar

JScrollPane

JSeparator

JSlider

JSplitPane

JTabbedPane

JTable

JTableHeader

*JTextComponent

JEditorPane

FrameEditorPane

JTextPane

JTextArea

JtextField

JPasswordField

JToolBar

JToolTip

JTree

JViewport

ScrollableTabViewport

Panel

Applet

JApplet

Window

Dialog

JDialog

Frame

JFrame

JWindow

Windows桌面应用程序开发Winform&WPF

Winform是XP时代的Windows 桌面程序开发技术。

采用C#语言开发UI和逻辑,没有使用标签语言写UI。

采用事件驱动方法。

Winform现在基本被淘汰了。

Winform是上一代的主流桌面应用程序开发开发技术,这个我从来没有用过,现在也基本不再使用了。

WPF是新一代微软图形界面开发技术。它是随着Windows Vista推出的。.NET Framework 3.0的一部分。它提供了统一的编程模型、语言和框架,真正做到了分离界面设计人员与开发人员的工作;同时它提供了全新的多媒体交互用户图形界面。

采用XAML标签式语言开发UI,可以在Expression Blend可视化设计开发。美工也可以轻易上手。XAML支持DataBind, Data(Item)Template, Style, Storyboard, Rescoure,自定义控件等技术,开发速度快。

支持事件驱动(Code behind)或者数据驱动(MVVM)开发模式

使用GC回收垃圾,XMAL和C#将编译成CLR中间运行语言,效率比较低,占用内存大

WPF的技术理念非常先进,开发过程也非常友好,也可以做出极为绚丽的界面,可是开发出来的应用体积较大,运行效率比较低,占用内存大,所以没有普及开来。(大部分我们常见的桌面应用都是C&C++开发)但是因为开发效率高,所以很多企业内部经常使用该技术。

Windows 10上的通用应用Universal WIndows APP(UWP)

Universal Windows App(UWP)也就是通用Window App 是微软最新的图形应用开发技术,它是基于WPF技术演进而来的。

UWP继承了所有WPF的优点,还可以使用C++和HTML&Javascript来开发,和WPF编译成中间代码不同,UWP直接将代码编译成机器码直接运行,极大的提高了效率。一次开发编译,可以同时在Windows 10,Windows 10 Mobile, XBOX,物联网IoT设备等其他Windows平台上运行

采用和iOS APP一样的沙盒机制,一样也有电话本,传感器,地图,推送等API。

采用响应式布局,可以适配任何分辨率等。

大量使用异步API,保证界面响应为最高级别。

我开发UWP并不多,但是我接触WPF的时间够长,所以UWP上手毫无压力。相比WPF运行在.NET运行时里,UWP是可以编译成Native Code运行,所以UWP运行效率更高,UI更为流畅。它是目前微软最为主推的开以技术。

Android

android开发,主要一xml来做界面(当然蛋疼手工写也可以。

一个界面xml对于一个active,active与active 桥接intent ,

但是,我更加喜欢iOS的界面开发模式(storybord,所以这里略过。

不过我觉得会ios开发的,上手android开发业不难

iOS

iOS应用是基于Cocoa框架上的,早期的Cocoa是用来开发Mac 应用的,后来加入了Cocoa touch层API用于iOS。

采用XIB或者Storyboard可视化搭建UI,也可以使用手写纯代码来开发UI。

采用Objective C 或者 Swift语言开发逻辑。

在Iphone5 加入多种分辨率后,苹果引入了Autolayout自动布局,它是一种基于约束的,描述性的布局系统。

默认严格遵守MVC设计模式,现以也可以使用MVVM开发框架。

采用ARC实现了自动内存管理。

iOS开发技术还有许多要点,这里就省略了,相信看到这篇文章的人都比较熟悉。

各平台UI开发小结

从上面可以看出,对于UI构建,都是采用类HTML语言。一个HTML标签表示一个View元素。它即可以当其他View的容器,也可以当内容或者数据的容器??梢杂枚懒⒌腟tyle文件来表示样式,也可以直接放在标签的属性里面。每个标签都可以有Name或者id属性来让js或者其他语言直接操作。

iOS其实也和上面的UI开发范式差不多,Storyboard内部其实也是一个XML文件,只不过我们不能直接编辑,只能可视化设计和通过代码操作。

Web界面的开发HTML&CSS

Web界面是以HTML标签的形式构建UI,它是HTML语言的最基本的单位。

用尖括号包围的关键词如

来表示UI元素,通常是成对出现。

如果需要在容器标签里放其他HTML单位,需要放在标签对里面。

一些HTML元素属性,放在第一个HTML标签里。以键值对的形式存在,比如type = 'text'。

使用Form来提交表单,Http(HTTPS)协议和服务器通讯。

通常通过CSS来控制HTML元素的外观。

通常通过Javescript来控制HTML元素。采用Ajax技术异步通信,实现局部刷新等。

这里就不给示例了,总是来说前端Web开发博大精深,新的技术框架层出不穷,当一个前端工程师也不容易。

从backbone,angular,到现在react+redux ,层出不穷,疲于奔命。你学了ie,还有firefox,还有chrome,……

一如前端深似海。

但是,前端的好处就是,统一GUI开发。我并不喜欢RN的开发模式,觉得还是

html+css+js 自己定制webkit壳,然后,你想怎么玩就怎么玩。(俗话中webapp……

吃饭去了,不扯了……

参考文章:http://www.open-open.com/lib/view/open1463552171634.html

转发注明出处:漫谈GUI开发-各种平台UI开发概况 - xml - 周陆军的个人网站http://www.zhoulujun.cn/zhoulujun/html/webfront/SGML/xml/2017_0330_7971.html

最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,944评论 25 707
  • 目录 什么是WPF? WPF的历史? 为什么要用WPF及WPF作用 WPF与winForm区别? 什么是WPF? ...
    灬52赫兹灬阅读 5,802评论 2 11
  • 一、与WPF结缘 第一次接触WPF是在2012年。学习了WinForm编程之后,了解到WPF这个非常先进的UI框架...
    金戈大王阅读 1,459评论 0 8
  • node 安装 双击下载好的 node 的 node-v10.1.0-x64.msi 文件到D盘 在cmd下输入n...
    持续积累阅读 645评论 0 0
  • 随着年龄增长,知道爱情都是会消逝的。起码,绝大部分人的爱情,从生理上来说,随着多巴胺水平回复正常值,热恋的激情都会...
    Maggie酱阅读 1,164评论 0 7