`
xhload3d
  • 浏览: 208321 次
社区版块
存档分类
最新评论

基于HTML5技术的电力3D监控应用(二)

阅读更多

我们选用HTML5技术还是顶着很大压力,毕竟HTML5技术性能行不行,浏览器兼容性会不会有问题,这些在项目选型阶段还是充满疑惑,项目做到现在终于快收尾了我们才敢松口气,压力基本顶住了,我个人总结的经验是:HTML5性能肯定不是最高,但对企业应用足够高效,HTML5标准不可能所有浏览器都一致实现,但对于企业应用已经足够工作。选择正确的引擎框架,进行合理的设计才是关键,HTML5真的已经Ready!

 

选择HTML5除了看中JavaScript动态语言的灵活性,能够很好的和其他异构系统融合到页面外,HTML5的跨平台性也是我们看中的重要原因,以前PC桌面应用上采用Flex和Silverlight到是可以跨平台,但如今的系统还不能上移动终端实在就说不过去了,而Flex和SL在跨移动终端方面就卡壳了,虽然有AIR可以导成native app应用,但还是远不如HTML5纯页面来的高效,每次修改任何东西PC上都可以模拟测试,看看Chrome DevTools for Mobile越来越屌爆的Screencast and Emulation功能: 

我现在测试移动终端大部分情况都不需要用真机,当PC上模拟测试得差不多后再进行真机测试基本都能一次性通过,回想以前用Flex的AIR进行转换Native App真是浪费生命,每次测试我都要刷几条微博消磨难熬的等待时间,上一次项目我们团队也分为Android和iOS两个完全采用独立Native开发方式,但也存在版本发布不一致,应用体验不一样,包括很多业务逻辑代码本可以复用的但由于Java和ObjectiveC的差异,搞得我们非得写两套一样逻辑的代码,其中加密的部分还得费劲的用C++实现了一个统一的实现,然后再有Java和OC分别去调用C++的代码,总之系统越搞越复杂,团队需要的人越来越多,当然我们经验不足也是一个原因,但我们毕竟是做企业应用搞项目的,不过可能有资源像BAT那些移动互联网巨头去慢慢融合摸索经验,我们除了这些基础技术外,还有学习很多电力业务,还得和硬件打交道,学习各种电力规约协议,扯淡了这么多你应该明白我们现在成功的使用了HTML5一个js语言就能跨所有平台之爽。

 

项目初期我们团队在选型初期对3D建模进行了一定的研究,传统的3D引擎一般只提供后期三维模型的渲染呈现,并不提供3D建模的解决方案,本以为还需要招聘专业的3DMax或Maya三维建模设计师,因为我们目前的美工设计师只会ps,但HT提供了一套完全基于HTML5的3D设计编辑工具,别说只会ps的美工设计师,其实后续项目的大部分3D场景我们程序员都参与了设计。

 

完全基于HTML5的设计器这点还是挺让我佩服的,虽然大家都在转型到HTML5但还很少有做得彻底的,如Google Web DesignerAdobe Edge Tools这些巨头的产物,包括Sencha Architect折腾了很长时间又走回Qt的路线,我实在不看好这些还不采用HTML5做设计器的路线,这时代HTML5已经足够强大,JS虚拟机的性能如V8也足够高效,数据直接云存储就可以,如果需要本地功能采用Node-Webkit也是很不错的方案。以前我们团队常用Qt或Java Swing来写些小工具,我发现这个项目历练之后Node-Webkit的技术方案成了大家些写工具应用的首选。

以下为几张运行系统抓图,以及这些系统图在编辑器内编辑的过程抓图

7
2
分享到:
评论
10 楼 xhload3d 2014-02-23  
hss118100 写道
我现在也在头疼电力画图选型到底是选svg/vml还是选canvas,看了楼主的博文,我感觉选canvas还是会更好一些 另外,楼主能否透漏一下你们的canvas框架用的是什么

www.hightopo.com HT for Web - Everything you need to create cutting-edge 2D and 3D visualization
9 楼 hss118100 2013-12-17  
我现在也在头疼电力画图选型到底是选svg/vml还是选canvas,看了楼主的博文,我感觉选canvas还是会更好一些 另外,楼主能否透漏一下你们的canvas框架用的是什么
8 楼 xhload3d 2013-12-17  
zha_zi 写道
你说的有道理,反正都是浏览的技术,具体情况具体分析,正因为有不同的场景才会催生不同的技术

7 楼 zha_zi 2013-12-17  
xhload3d 写道
zha_zi 写道
canvas 是标准的位图技术,非矢量图技术,目前主流的矢量图技术可以也就是flash 和SVG 了,你可把你渲染后的图形看一下是不是可以任意缩放你就明白了,我说canvas性能低下是是js执行机制的问题,跟你加载多少万个元件并没有直接关系,js是原生的单线程,在做轮询做动画切换的时候画面动态会不细腻很难精准控制,你可以在试一下加载一百个js控制的动画元件会是什么效果,还有不是svg封装了动画而是svg 支持smil协议,目前除去IE意外的浏览器都是支持的,还有就是canvas没有原生事件支持,我不相信三方框架做的事件支持会比浏览器原生的事件支持还要优秀,如果这些东西在canvas中都是标准性的对开发者来说不是一件好事情吗?纯技术讨论,谢谢可能我理解有限,若有错误可以指出

感谢你的回复,Flash和SVG底层也是用基本的2D(也会有GPU的优化)模式来实现,flash的vm和svg的浏览器实现源代码也是调用2D的API实现,所以在我看来flash和svg是2dAPI之上的产物。
cavnas自然可以实现scale缩放,只要自己定义类似svg或vml或pdf等任何矢量的描述标准后都可以用cavnas来实现,因此会有http://fabricjs.com/ 这样SVG-to-canvas的产物出现,至于性能的话优化空间主要看具体项目应用,我不是做游戏领域所以可能对我们来说动画只是示意,用户能看到告警或者状态信息就可以了,至于动画是否匀速,是否精确对于我们这种应用来说不是很关键,因此这方面来说cavnas和js对我们还是足够用的。
最后你提到的“我不相信三方框架做的事件支持会比浏览器原生的事件支持还要优秀“这点还是得看具体应用,浏览器的事情要考虑大而全的整体html标准,因而对于垂直应用领域专业的第三方框架会更优秀的多,例如OpenGL虽然是3D标准了,但Unity3d也活得很好,Cocos2d也活得很好,第三方框架肯定会着重于你是应用游戏领域,你是应用电信领域,你是应用电力领域,你是应用仿真领域,你是应用生物学领域,你是应用工业控制领域而存在,所以笼统的说第三方就不如原生的说法我感觉意义不大,不同领域问题是多样的,肯定需要不同工具来搞定不同问题。
当然我也不是canvas的拥护者或svg的反对派,只不过canvas的2D和3D满足了我们这次项目的电力需求,对于其他应用肯定也有svg强项的方面

你说的有道理,反正都是浏览的技术,具体情况具体分析,正因为有不同的场景才会催生不同的技术
6 楼 xhload3d 2013-12-17  
zha_zi 写道
canvas 是标准的位图技术,非矢量图技术,目前主流的矢量图技术可以也就是flash 和SVG 了,你可把你渲染后的图形看一下是不是可以任意缩放你就明白了,我说canvas性能低下是是js执行机制的问题,跟你加载多少万个元件并没有直接关系,js是原生的单线程,在做轮询做动画切换的时候画面动态会不细腻很难精准控制,你可以在试一下加载一百个js控制的动画元件会是什么效果,还有不是svg封装了动画而是svg 支持smil协议,目前除去IE意外的浏览器都是支持的,还有就是canvas没有原生事件支持,我不相信三方框架做的事件支持会比浏览器原生的事件支持还要优秀,如果这些东西在canvas中都是标准性的对开发者来说不是一件好事情吗?纯技术讨论,谢谢可能我理解有限,若有错误可以指出

感谢你的回复,Flash和SVG底层也是用基本的2D(也会有GPU的优化)模式来实现,flash的vm和svg的浏览器实现源代码也是调用2D的API实现,所以在我看来flash和svg是2dAPI之上的产物。
cavnas自然可以实现scale缩放,只要自己定义类似svg或vml或pdf等任何矢量的描述标准后都可以用cavnas来实现,因此会有http://fabricjs.com/ 这样SVG-to-canvas的产物出现,至于性能的话优化空间主要看具体项目应用,我不是做游戏领域所以可能对我们来说动画只是示意,用户能看到告警或者状态信息就可以了,至于动画是否匀速,是否精确对于我们这种应用来说不是很关键,因此这方面来说cavnas和js对我们还是足够用的。
最后你提到的“我不相信三方框架做的事件支持会比浏览器原生的事件支持还要优秀“这点还是得看具体应用,浏览器的事情要考虑大而全的整体html标准,因而对于垂直应用领域专业的第三方框架会更优秀的多,例如OpenGL虽然是3D标准了,但Unity3d也活得很好,Cocos2d也活得很好,第三方框架肯定会着重于你是应用游戏领域,你是应用电信领域,你是应用电力领域,你是应用仿真领域,你是应用生物学领域,你是应用工业控制领域而存在,所以笼统的说第三方就不如原生的说法我感觉意义不大,不同领域问题是多样的,肯定需要不同工具来搞定不同问题。
当然我也不是canvas的拥护者或svg的反对派,只不过canvas的2D和3D满足了我们这次项目的电力需求,对于其他应用肯定也有svg强项的方面
5 楼 zha_zi 2013-12-17  
xhload3d 写道
zha_zi 写道
xhload3d 写道
zha_zi 写道
我们做的组态监控软件第一版也是基于html5 canvas 使用的是kineticjs框架,后来发现有些方面canvas 不能满足后来换成了SVG技术 。

所以文中提到“选择正确的引擎框架,进行合理的设计才是关键”,也许是kineticjs的不足而非canvas

kineticjs 还是比较强大的版本更新,bug修复非常快,主要原因当时需要软件做矢量化,canvas不是矢量化技术,所以最后放弃了,canvas 原生支持的api实在是太少了,几乎所有功能都要依赖于三方框架解决,性能问题,js执行机制,渲染问题,感觉canvas距离真正做大型复杂动画还有一段距离

所以还是框架的问题,cavnas天生就是矢量,你只需要的只是一种描述,hightopo.com我们现在也用了他们的矢量功能,这个后续我可以再写文章介绍。SVG是可以有元素的直接事件和操作,但只要框架良好的封装Canvas上提供这些事件也是基本框架应该做的功能。

至于SVG和Canvas的性能,我们现在测试HT的组件都是以万甚至10万的压力在测试,你可以试试SVG加载1万个元素的体验。

最后你提到了Canvas的API少得问题,这个是事实但不是问题,Canvas的确只有小几十的API数量,但这些基本函数已经足够封装常规的应用,如果需要更高性能更变态的渲染那就是WebGL的强项了,但SVG的太过“丰富”也是他的短板,SVG封装到了filter甚至封装了动画等等效果,但各种浏览器的支持差异巨大,其实作为产品最终往往考虑兼容性能用到的函数还是最基本的那些,所以从这点来说我感觉Canvas的API少不是太大问题。

不过kineticjs我没研究过,想必zha_zi同学还是挺有研究的,我说得可能不客观,呵呵

canvas 是标准的位图技术,非矢量图技术,目前主流的矢量图技术可以也就是flash 和SVG 了,你可把你渲染后的图形看一下是不是可以任意缩放你就明白了,我说canvas性能低下是是js执行机制的问题,跟你加载多少万个元件并没有直接关系,js是原生的单线程,在做轮询做动画切换的时候画面动态会不细腻很难精准控制,你可以在试一下加载一百个js控制的动画元件会是什么效果,还有不是svg封装了动画而是svg 支持smil协议,目前除去IE意外的浏览器都是支持的,还有就是canvas没有原生事件支持,我不相信三方框架做的事件支持会比浏览器原生的事件支持还要优秀,如果这些东西在canvas中都是标准性的对开发者来说不是一件好事情吗?纯技术讨论,谢谢可能我理解有限,若有错误可以指出
4 楼 xhload3d 2013-12-17  
zha_zi 写道
xhload3d 写道
zha_zi 写道
我们做的组态监控软件第一版也是基于html5 canvas 使用的是kineticjs框架,后来发现有些方面canvas 不能满足后来换成了SVG技术 。

所以文中提到“选择正确的引擎框架,进行合理的设计才是关键”,也许是kineticjs的不足而非canvas

kineticjs 还是比较强大的版本更新,bug修复非常快,主要原因当时需要软件做矢量化,canvas不是矢量化技术,所以最后放弃了,canvas 原生支持的api实在是太少了,几乎所有功能都要依赖于三方框架解决,性能问题,js执行机制,渲染问题,感觉canvas距离真正做大型复杂动画还有一段距离

所以还是框架的问题,cavnas天生就是矢量,你只需要的只是一种描述,hightopo.com我们现在也用了他们的矢量功能,这个后续我可以再写文章介绍。SVG是可以有元素的直接事件和操作,但只要框架良好的封装Canvas上提供这些事件也是基本框架应该做的功能。

至于SVG和Canvas的性能,我们现在测试HT的组件都是以万甚至10万的压力在测试,你可以试试SVG加载1万个元素的体验。

最后你提到了Canvas的API少得问题,这个是事实但不是问题,Canvas的确只有小几十的API数量,但这些基本函数已经足够封装常规的应用,如果需要更高性能更变态的渲染那就是WebGL的强项了,但SVG的太过“丰富”也是他的短板,SVG封装到了filter甚至封装了动画等等效果,但各种浏览器的支持差异巨大,其实作为产品最终往往考虑兼容性能用到的函数还是最基本的那些,所以从这点来说我感觉Canvas的API少不是太大问题。

不过kineticjs我没研究过,想必zha_zi同学还是挺有研究的,我说得可能不客观,呵呵
3 楼 zha_zi 2013-12-17  
xhload3d 写道
zha_zi 写道
我们做的组态监控软件第一版也是基于html5 canvas 使用的是kineticjs框架,后来发现有些方面canvas 不能满足后来换成了SVG技术 。

所以文中提到“选择正确的引擎框架,进行合理的设计才是关键”,也许是kineticjs的不足而非canvas

kineticjs 还是比较强大的版本更新,bug修复非常快,主要原因当时需要软件做矢量化,canvas不是矢量化技术,所以最后放弃了,canvas 原生支持的api实在是太少了,几乎所有功能都要依赖于三方框架解决,性能问题,js执行机制,渲染问题,感觉canvas距离真正做大型复杂动画还有一段距离
2 楼 xhload3d 2013-12-16  
zha_zi 写道
我们做的组态监控软件第一版也是基于html5 canvas 使用的是kineticjs框架,后来发现有些方面canvas 不能满足后来换成了SVG技术 。

所以文中提到“选择正确的引擎框架,进行合理的设计才是关键”,也许是kineticjs的不足而非canvas
1 楼 zha_zi 2013-12-16  
我们做的组态监控软件第一版也是基于html5 canvas 使用的是kineticjs框架,后来发现有些方面canvas 不能满足后来换成了SVG技术 。

相关推荐

    基于HTML5的移动船舶监控应用研究.zip

    在基于HTML5的移动船舶监控应用研究中,我们主要关注的是如何利用这项技术实现跨平台的应用开发,以适应移动互联网的发展趋势。HTML5不仅改进了对多媒体的支持,如音频、视频和图像,还引入了离线存储、拖放功能、 ...

    基于大数据技术的视频监控应用探讨.pdf

    大数据技术在视频监控应用中的探讨主要涉及以下几个方面: 1. 大数据技术的重要性:文章指出,随着我国社会经济的快速发展,大数据技术开始在民众生活及社会生产中发挥越来越重要的作用。然而,我国视频监控领域对...

    基于物联网技术的电力重点物资运输监控应用研究.pdf

    基于物联网技术的电力重点物资运输监控应用研究.pdf

    物联网技术在电力智能监控系统中的应用探究.pdf

    本文主要探讨了物联网技术在电力智能监控系统中的具体应用和设计,以及如何通过这些技术提高电力系统的监控效率和安全性。 首先,智能监控系统的构建是物联网技术应用的核心。在电力系统中,智能监控主要通过三个...

    html5绘图工具 基于 HTML5 的 Canvas 技术,拓扑图是电力

    HTML5 是一种强大的 web 开发技术,它在网页...通过这样的方式,HTML5 和 Canvas 结合 JTopo 等绘图库,能够在网页上实现灵活且功能丰富的电力或电信行业的拓扑图应用,帮助工程师进行系统监控、故障排查和网络规划。

    基于云计算技术的电力视频监控网络设计与实现.pdf

    云计算技术的应用使得电力视频监控系统变得更为高效、智能和稳定,有效地支持了电力体系的正常运行,并对故障诊断和处理提供了新的解决途径。通过建立云计算平台,实现了监控信息和管理系统的实时共享和交互,工作...

    基于物联网技术的电力重点物资运输监控应用研究.zip

    《基于物联网技术的电力重点物资运输监控应用研究》是一篇深入探讨如何利用物联网技术优化电力行业重点物资运输管理的研究报告。物联网(Internet of Things, IoT)是近年来信息技术领域的一个重要发展方向,它通过...

    IEC60870-5-104规约在分布式电力监控系统中的应用.pdf

    IEC60870-5-104规约是一种用于电力系统自动化领域的通信协议标准,被广泛应用于分布式电力监控系统中。在电网调度中心的通信要求中,高数据容量和高速率数据通信是关键指标,而IEC60870-5-104规约正是为了满足这一...

    基于电力载波的监控系统的实现

    本文对低压电力线通信技术进行了深入研究,探讨了其在监控系统中的应用可行性。作者首先概述了PLC的理论基础和当前的工业应用状况,展示了该技术在电力市场和相关业务中的潜力。接着,通过对实际测量数据的分析,...

    基于工业以太网的煤矿电力监控系统的应用

    基于工业以太网的煤矿电力监控系统是针对煤矿电力供应的特殊要求而设计的监控系统。它的应用目标是实现煤矿供电系统的自动化、智能化监控,以提高煤矿的生产效率,降低人力成本和安全生产风险。该系统的组成包含以下...

    基于PLC技术的水利自动化监控系统的构建与应用.pdf

    文章主要讨论了基于PLC(可编程逻辑控制器)技术的水利自动化监控系统的设计与应用,涵盖了PLC技术的简介、水利自动化监控系统的设计和应用以及PLC技术在水利自动化监控系统中的发展现状。 1. PLC技术简介: PLC...

    电力监控系统.pdf

    电力监控系统的主要功能模块包括PAS(能量管理系统高级应用)、通信管理、实时监控、报警处理、数据存储、设备管理、统计分析、报表管理、视频联动、3D可视化系统组态、数据库管理、两票管理、Web发布以及手机APP等...

    基于网络安全管理平台的电力监控系统网络安全应用实践.pdf

    本文档提供了基于网络安全管理平台的电力监控系统在网络安全应用方面的实践案例,并从功能介绍、典型设备接入和网络安全技术应用三个方面进行深入研究。 网络安全管理平台的建设基于C/S架构,运行在安全防护区...

    HTML5 WebGL 3D 仓储管理系统

    在本文中,我们将深入探讨HTML5、WebGL以及3D技术在仓储管理系统中的应用。 HTML5是超文本标记语言(Hypertext Markup Language)的第五个版本,它在传统HTML的基础上增加了许多新特性,如离线存储、拖放功能、媒体...

    电力电子技术在太阳能发电中的应用.doc

    其应用包括太阳能光伏发电技术、电力电子设备在光伏系统中的应用、稳定电压和电流的输出、提高太阳能光伏发电的效率和系统的控制和监控等。 电力电子技术在太阳能发电中的应用还存在一些挑战和问题,如电力电子设备...

    基于大数据背景的电力运营监控数据处理研究.pdf

    大数据时代背景下的电力运营监控数据处理研究涉及众多关键知识点,本篇研究主要集中在对大数据特征的阐述,电力监控数据分析特点的介绍,以及基于大数据处理技术在电力运营监控领域的应用。 首先,大数据的定义与...

    电力GIS的实时监控实现技术

    电力GIS实时监控技术的研究是计算机技术在电力行业的一个重要应用方向。电力行业作为国民经济的关键部门之一,其运行状态直接影响着国家经济发展和社会稳定。为了提升电力系统的管理水平和服务质量,电力GIS与实时...

    基于物联网技术的电梯远程监控应用探讨.pdf

    基于物联网技术的电梯远程监控应用探讨.pdf

    基于容器技术的电力系统业务应用资源池系统设计研究.pdf

    本文主要探讨了基于容器技术的电力系统业务应用资源池系统的设计与研究,旨在应对电力系统业务平台规模日益扩大,传统基础设施无法满足信息化发展需求的问题。云南电网有限责任公司采用容器虚拟化技术构建云计算业务...

Global site tag (gtag.js) - Google Analytics