在SAP UI中使用纯JavaScript显示产品主数据的3D模型视图
在Jerry写这篇文章时,通过Google才知道,SAP其实是有自己的3D模型视图显示解决方案的。
故事要从Right Hemisphere说起,这是一家专业的企业级2D/3D模型浏览及转换的软件供应商。后来,Right Hemisphere被SAP收购,解决方案也更名为SAP Visual Enterprise。
收购之后,SAP推出了一系列和Visual Enterprise Viewer的集成解决方案。以SAP CRM为例,在CRM产品主数据的页面工具栏上新增了一个按钮"Visual Enterprise Viewer",点击之后,会显示一个弹出窗口,在浏览器里利用ActiveX调用本地安装的Viewer应用,显示该产品主数据的3D视图。
这种产品3D模型显示功能在CRM领域的用途是,充分利用企业已有的3D模型的素材文件(通常是企业专门的工程/设计部门或者外包部分通过专门的3D建模软件制成),在CRM销售,服务和营销场景中也能给用户提供关于产品的一个360度视图。比如一个组成复杂的大型机械,通过3D模型展示发生故障的部件,或是作为帮助文档的补充给用户展示产品的组装步骤,或是在服务流程中以3D方式显示出所有可选备件,给用户更好的视觉体验等等。
这种基于SAP Visual Enterprise Viewer的3D显示解决方案的技术实现是建立在WebClient UI框架的增强之上,即引入了一个新的标签veviewerIsland, 将通过ActiveX启动本地安装的Viewer应用的逻辑封装在内。
因为和本文主题无关,不做深入介绍,感兴趣的朋友请参考SAP help上关于
SAP Visual Enterprise Viewer的介绍。
https://help.sap.com/viewer/p/SAP_3D_VISUAL_ENTERPRISE_ACCESS
本文介绍的是另一种用纯JavaScript编程来以3D方式显示产品主数据的解决方案。对于用户来说,使用该解决方案无需在客户端安装任何3D显示软件,只需要一个支持WebGL的现代浏览器即可。
我做了一个简单的原型,把它的视频放到了youtube上:
https://www.youtube.com/watch?v=piWsbfPEGUA
(因为这个视频是在我的内部系统上录的,在显示3D模型的弹出窗口的地址栏里显示了内部系统的url,为了不泄漏出来,我在视频里把弹出窗口的顶部截掉了)
当工具栏上的3D按钮点击之后,出现一个新的弹出窗口,效果和使用SAP Visual Enterprise Viewer解决方案一样,并且还多了一个动态旋转的效果,使用户能够全方位地观察到该足球每一个部位。
正如文章标题所示,这个解决方案里3D显示的技术实现采取的是纯JavaScript编程。奥妙就在threejs,一个基于WebGL,使用JavaScript进行3D模型变换和显示的库。
在threejs的官网能找到很多用threejs开发而成的酷炫效果和使用教程。
下面是我做的原型主要的开发步骤,感兴趣的顾问朋友们可以在自己系统试试。
1. 在SE80里开发一个BSP应用,该应用负责使用threejs API基于已有的3D模型素材文件渲染出一个不断旋转的3D足球。
选中index.htm, 从右键菜单里选择"test", 在弹出的浏览器窗口内您会看到一个旋转的3D足球。这个文件的全部源代码请在我的github上获得。
https://github.com/i042416/FioriODataTestTool2014/blob/master/WebContent/096_3dfootball.html
该文件内的逻辑为使用threejs API进行3D模型的创建和渲染,具体技术细节大家可以参考threejs官网教程。这个文件的代码是Jerry从我的同事Wen Aviva的代码复制而成,做了极少量的修改。
插播一条八卦
Aviva是SAP成都研究院C4C开发团队一位具有女王级地位的程序媛,有图为证:
今年3月份,SAP C4C全球开发部门搞了一个内部编程马拉松大赛。SAP成都和美国,印度的其他C4C开发团队全部参加了这次比赛。每个参赛队伍组队完成后,需要给比赛开发的作品取个名字。成都一位组员提出了取名"Hi Aviva!", 为的是向Aviva致敬,该提议获得了组内全票通过。最后这个小组的作品获得了二等奖,因此Aviva的名字又出现在了公司portal和内网页面上。
为什么Aviva在组内享有这种女王级的地位?因为技术栈全面,在工作中能自如地运用C++,Java和JavaScript完成标准开发和原型开发任务,经常能帮团队解决一些很难的技术问题,而且学习新技术速度特别快。Jerry在SAP成都研究院工作11年,和很多程序媛共事过,Aviva的技术能力给我留下非常深刻的印象,另一位是Mao Annie。
Jerry非常佩服这两位程序媛,能够把自己的技术修炼到如此程度。
Aviva以前的微信头像是一位坐在电脑面前编程的程序媛的卡通图像。最近换了。
八卦插播结束。
如果大家不想自己动手,可以直接打开下面这个url,查看这个旋转的3D足球的效果。
http://i042416.github.io/FioriODataTestTool2014/WebContent/096_3dfootball.html
请注意,因为这个足球的3D素材文件数量比较多,需等待它们全部成功从浏览器加载后,才能看到最终效果。
另外,在这个原型里,这些素材文件都是直接维护在BSP应用里的。如果做成标准解决方案,则应维护在CRM产品页面的“附件”区域,或是维护在ERP对应的物料主数据应用里。
3D模型的旋转效果通过了大部分现代浏览器支持的原生API requestAnimationFrame来实现。传一个render函数进去,默认情况下每秒钟会被调用60次,每次函数调用里对模型的X和Y坐标做微调,以造成旋转的视觉效果。
2. 剩下的开发全部是传统的CRM WebClient UI开发了。
对UI组件PRD01OV做增强,添加一个新的Component usage,消费组件GSURLPOPUP,这个组件作为显示3D模型的页面容器。
在产品主数据的UI工具栏上增加一个新的按钮:
实现该按钮的点击响应处理:
点击之后,在GSURLPOPUP里显示我们第一步做好的BSP应用,在该应用里用threejs渲染出3D模型:
欢迎试用该原型,并提出您的宝贵意见。
感谢阅读。
要获取更多Jerry的原创技术文章,请关注公众号"汪子熙"或者扫描下面二维码:
在SAP UI中使用纯JavaScript显示产品主数据的3D模型视图的更多相关文章
- ASP.NET Core 在 Swagger UI 中显示自定义的 Header Token
Swagger 是个好东西,对于前后端分离的网站来说,不仅是提高前后端开发人员沟通效率的利器,也大大方便了后端人员测试 API.有时候,API 中可能需要在 Header 中设置认证参数,比如 aut ...
- android 在你的UI中显示Bitmap - 开发文档翻译
由于本人英文能力实在有限,不足之初敬请谅解 本博客只要没有注明“转”,那么均为原创,转贴请注明本博客链接链接 Displaying Bitmaps in Your UI 在你的UI中显示Bitmap ...
- SAP UI 搜索分页技术
搜索分页技术往往和另一个术语Lazy Loading(懒加载)联系起来.今天由Jerry首先介绍S/4HANA,CRM Fiori和S4CRM应用里的UI搜索分页的实现原理.后半部分由SAP成都研究院 ...
- 纯javascript验证,100行超精简代码。
这篇文章转自--寒飞,原帖地址http://blog.csdn.net/luoyehanfei/article/details/42262249 QQ交流群235032949 纯javascript验 ...
- 纯javaScript、jQuery实现个性化图片轮播
纯javaScript实现个性化图片轮播 轮播原理说明<如上图所示>: 1. 画布部分(可视区域)属性说明:overflow:hidden使得超出画布部分隐藏或说不可见.position: ...
- ECharts-基于Canvas,纯Javascript图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表
ECharts http://ecomfe.github.com/echarts 基于Canvas,纯Javascript图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表.创新的拖拽重计算 ...
- ios开发UI篇—使用纯代码自定义UItableviewcell实现一个简单的微博界面布局
本文转自 :http://www.cnblogs.com/wendingding/p/3761730.html ios开发UI篇—使用纯代码自定义UItableviewcell实现一个简单的微博界面布 ...
- javascript日历控件——纯javascript版
平时只有下班时间能code,闲来写了个纯javascript版.引用该calendar.js文件,然后给要设置成日历控件的input的id设置成calendar,该input就会变成日历控件. < ...
- 青瓷引擎之纯JavaScript打造HTML5游戏第二弹——《跳跃的方块》Part 10(排行榜界面&界面管理)
继上一次介绍了<神奇的六边形>的完整游戏开发流程后(可点击这里查看),这次将为大家介绍另外一款魔性游戏<跳跃的方块>的完整开发流程. (点击图片可进入游戏体验) 因内容太多,为 ...
随机推荐
- codeforces 673D D. Bear and Two Paths(构造)
题目链接: D. Bear and Two Paths time limit per test 2 seconds memory limit per test 256 megabytes input ...
- 并不对劲的bzoj5415:loj2718:uoj393:p4768:[NOI2018]归程
题目大意 \(n\)(\(n\leq2*10^5\))个点,\(m\)(\(m\leq4*10^5\))条边的图,每条边有海拔\(a_i(a_i\leq10^9)\).长度\(l_i(l_i\leq1 ...
- appium九宫格解锁错误提示:The coordinates provided to an interactions operation are invalid解决办法
原文地址:http://blog.csdn.net/qqtMJK/article/details/77838814 今天做自动化解锁9宫格,发现swipe不能满足需求,于是用TouchAction去实 ...
- caffe 入门实例3 fine-turning
占坑,使用fine-turning初始化参数...
- View Controller Programming Guide for iOS---(一)---About View Controllers
About View Controllers View controllers are a vital link between an app’s data and its visual appear ...
- 使用mysqlfrm恢复frm表结构,获得建表语句
1.mysqlfrm 是一个恢复性质的工具,用来读取.frm文件并从该文件中找到表定义数据生成CREATE语句. 下载链接:https://downloads.mysql.com/archives/u ...
- python学习笔记5-自定义函数
1 自定义函数 (1)函数代码块以def关键字开头,然后函数标识符名称和圆括号 (2)任何传入参数和自变量必须放在圆括号中间.圆括号之间可以用于定义参数 (3)函数的第一行语句可以选择性的使用文 ...
- iOS后台模式BackgroundMode
概述 iOS平台提供给应用特殊的后台服务,应用在后台时仍被允许能执行一会. 后台模式 UIBackgroundModes Xcode Modes 1. audio -> Audio.Airpla ...
- 第十五篇 .NET高级技术之正则表达式
正则表达式 正则表达式是对字符串进行匹配的语法,像name like '%李%'一样,定义了一些特殊的“元字符”,用来判断一个字符串是否满足某个规则.正则表达式非常深,编译器都是基于正则表达式,掌握基 ...
- 一个关于国密SM4的故事
一个关于国密SM4的故事 我的名字叫SM4,我还有三位兄长,分别是大哥SM1, 二哥SM2, 和三哥SM3.说起我的名字,故事要回到2006年的时候,我出生的时候并不是叫SM4的,而是叫做SMS4.只 ...