设为首页 收藏本站
查看: 965|回复: 0

[经验分享] 客户端GUI程序开发漫谈

[复制链接]

尚未签到

发表于 2017-2-24 07:28:56 | 显示全部楼层 |阅读模式
  这篇文章包含了这个领域的很多开源项目的介绍,还有我多年来的心血和汗水


去年夏天的时候,我用QT做了一个小工具
  后来还用QT做了流程设计器
  我把程序分享给飞扬青云之后,他甚至搞出来一套QT的皮肤来
  说实在的,QT确实挺强大的,
  如果你有一个项目,需要跨平台GUI开发,你又有一个C++团队的话,
  那么做技术选型的时候,可以负责任的说,QT是不二之选
  这时可能有人会提到GTK+,
  我想说的是GTK+对windows平台的支撑力度实在是少的可怜
  linux的版本已经到了3.16了,windows的版本才到3.6,整整差10个版本(我这里说的是GTK3)
  而且大部分常见的控件在windows上都没有
  来看看我在一个开源项目上踩的坑吧。
  当然还有人可能提到wxWidgets,这玩意儿我没有深入研究过
  只知道它是在原生图形API上再做的包装,想想windows API搞出来的窗口有多古板,还是算了。
  类似的还有iup,跟wxWidgets的原理是一样的。
  还有人直接用游戏库做GUI程序的,比如nimx和nanovg
  nimx是基于SDL2图形引擎搞出来的GUI框架
  我在nimx上踩到两个坑,其中一个提交pull request给作者,作者也认了
  第二个坑就直接把我坑死了。
  nanovg是基于OpenGL图形引擎搞出来的GUI框架。
  这个项目还是in progress状态。
  总之,这两个项目都不能用于生产。
  说到这里不得不说轮子兄搞的gacui
  (我本想说,国内轮子兄...,但貌似他也已经肉身FQ了,再提国内也不对了)
  这个项目我了解的不多,只在14年春天的时候,搭过环境,写过hello world
  前段时间学习nim语言,兴致勃勃跑到github上问作者要dll,打算用nim做个包装
  后来才知道,作者是不会提供了,好遗憾。
  gacui的原理我不太清楚,只知道有GPU加速。
  当然还有基于Direcut UI发展而来的duilib
  这个库也是国内一位朋友搞出来的
  据说很多大厂的客户端都在用这个开源库
  duilib应该是受这个项目的启发才建成的
  国内很著名的一个收费UI库UI Power也是基于这个思路搞出来的
  在国内开发GUI应用程序,更多的还是给windows平台下的用户用
  如果你想最大自由度的定制你的界面,又不想让你的程序的发型版看起来太大
  那么duilib是个不错的选择,但duilib文档太少(作者自己也这么说),你要做足这方面的准备
  好在是开源的,你C++够牛的话,也不用担心
  当然如果你希望有完善的文档来给你提供帮助的话,
  那么你可以选择Qt,毕竟是国外大厂商,源码、IDE、文档、社区都很齐全
  这里不得不提一下国内的qtcn社区,挺不错的,里面有不少这个领域的专家,而且都挺热情的
  但是Qt的依赖库库实在太多,你开发好的程序怎么着也得有个十几兆,才能分发给别人。
  而且我相信你肯定会用到process explorer或者dependencywalker之类的工具来查找你的程序到底依赖了哪些dll
  好吧,如果你足够厉害、有一台性能超赞的电脑、有一两个小时的时间,你可以尝试静态编译QT
  如果你开发的GUI程序只给windows平台下的用户用
  那么最最基本的三个选择:windows api、MFC、WTL
  用windows api做GUI程序,比较辛苦,因为它就是一系列的API,所有的事情都得你自己来做
  MFC是一套非常庞大的类库,他里面包含了一系列的C++的机制,用起来非常繁琐
  WTL比MFC简单,比windows api易用,但资料很少
  你如果要走WTL这条路,那么你一定会看《深入解析ATL》这本书(友情提醒,这本书最新版翻译的实在太烂了)
  好,再来说用混合开发技术做GUI程序
  这种技术方式的主要原理就是:
  你写代码包住浏览器内核,
  界面代码用HTML/CSS/JS完成(这是最大的优势,你可以用所有与之相关的库)
  所有与界面渲染相关的事情交给浏览器内核完成,
  所有与系统相关的事情你自己完成
  这项技术在移动端用的挺好的,
  比如说国外的:phonegap、cordova
  还有国内的:mui、appcan
  如果你要做一个移动端的项目,又打算走混合开发这条路的话,
  我强烈推荐dcloud的mui,真的很不错,
  appcan很早之前了解过一点,貌似是收费的
  PC端的混合开发就不那么火了,
  但有很多大厂偷偷也在用这个技术,比如:鹅厂
  如果你要做PC端的混合开发,
  你有三条路可以走,
  封装IE浏览器的内核、
  封装谷歌浏览器的内核、
  封装Webkit浏览器的内核、
  封装firefox浏览器的内核
  如果你要选用IE浏览器的内核,
  那么你就不可能考虑跨平台的事情了,
  而且,因为你的用户可能使用了不同的windows操作系统
  所以你要做好客户端IE浏览器版本不一致的准备
  IE6\7\8\9\10\11...
  到IE9才可以称得上现代化的浏览器,市面上很多前端库,也只兼容到IE9
  用IE内核来做这个事情的好处是:
  你不用把浏览器的一堆DLL,分发给你的客户,这是其他三个方案所不能比的。
  webkit和firefox真是挺尴尬的
  性能表现没有谷歌浏览器好
  平台支撑没有IE浏览器好
  我对firefox浏览器的Gecko内核几乎没有什么研究
  (之前做浏览器插件的时候看过他的API,现在几乎都忘记了)
  Qt在去年之前还只有对webkit的封装
  我曾经在前年,把webkit和extjs整合起来,做了一个库,
  大家可以研究一下,但请不要用于生产,我已经不再维护这个库了
  国外也有人用.net封装过webkit,但作者在10年左右,就不再维护这个项目了
  终于说到谷歌浏览器的内核:chromium
  我实在是不建议直接研究它
  你可以看看CEF这个项目
  这个项目是用C++对chromium做的包装
  之前不支持中文输入法的光标跟随,现在也已经被fix掉了
  如果你是C#开发人员,也想用CEF的话,
  那么你可以考虑使用cefglue、cefsharp、chromiumfx
  这三个项目我都用过,目前的状况来看,我推荐最后一个
  我曾经写过一系列的文章来介绍这个东西
  你如果是一个JS开发人员的话,
  有我nodejs的庇佑,你完全不用care   CEF这种东西
  你可以直接选用nw.js
  这个东西,我也用过,
  除了nodejs带来的那些缺点,
  他几乎是完美的,非常不错,推荐使用
  还想再多说一些,但忽然发现,篇幅已经太长了,借曹雪芹的一首诗止笔:
  满纸荒唐言!一把辛酸泪!一把辛酸泪!一把辛酸泪!.......

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-346326-1-1.html 上篇帖子: 国内最大的 Node.js 社区将 New Relic 的监控产品换成了 iyunv 下篇帖子: 免费的编程中文书籍索引
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表