SuperMap iClient3D for WebGL教程(Entity)-Knockout

2024-02-25 09:58

本文主要是介绍SuperMap iClient3D for WebGL教程(Entity)-Knockout,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者:为梦齐舞

本文同步更新于简书文章https://www.jianshu.com/p/54a80317d6b5
我们经常使用到这样的功能,我们在界面里面拖动一个滑动条,模型就变小或者变大了;我们拖动一个滑动条,场景颜色变暗淡了,我们输入一个数字,我们的体重就变…这里就想想就好啦
bbaa.gif
这一切的原因都归功于Cesium.knockout;但需要注意Cesium中的knockout与Knockoutjs,功能层面上有大多数是相同的,但是他俩不是完全一样的;但是Cesium中使用了Knockoutjs的库,目前的1.55版本是引用了Knockoutjs的v3.4.2版本,所以这里我们索性来了解下Knockoutjs这个库,不要问我为什么,我就是想学习下。

一、Knockout.js介绍

Knockoutjs是一个轻量级的MVVM库,专注于实现数据与视图的绑定,本身并不提供 UI 类和路由等功能,能够友好地处理数据模型和界面DOM的绑定,并且是双向绑定,和VUE中的v-model功能类似哦,这样可以极大的减少代码量和对DOM元素的操作监控,关于啥是MVVM看图说话吧。
MVVM模式

试想没有Knockoutjs的时候我们需要监测DOM的变化,我们会用到什么,jquery的bind?还是注册一个Dom的on某某事件,不管怎么样,后期的改变时都需要和DOM操作,当还是几个DOM的操作时,是可以忍忍算了,但是50个呢,100个呢,甚至更多,代码量会成倍的增加,并且代码复用性不高,用一个高上大的词,耦合度太高。

1、Knockout.js中的监控属性observable

先上一张图看效果,看着效果如何?
监控属性
接着来看代码,我们来看下实现步骤:
a、定义viewmodel,这里我们定义为model,里面两个属性,一个数量,一个总价。
b、与Dom绑定,我们使用data-bind绑定了值。(对应input标签的文本,需要使用textinput,而普通标签的文本使用text即可)
c、使用ko.observable绑定了num对象
d、使用计算监控属性ko.pureComputed,计算总价
d、激活knockout的绑定,也就是ko.applyBindings(model);

<body><p>价格:1000</p><a>数量:</a><input type="text" data-bind='textinput:num' /><br /><br /><a>总价:</a><a  data-bind='text: total'></a ><script type="text/javascript">var model={num:ko.observable(12),total:123};			model.total = ko.pureComputed(function () {return 1000*model.num();})ko.applyBindings(model);</script></body>

看到这里我想你会说,这也没有啥啊,我用textchange照样实现一样的功能,当然你说观点完全正确,无可反驳,但是observable意义在于不操作DOM,我们在JS中只需要关心怎么修改model.num(),而不是如何操作DOM。
另外提一句,ko.pureComputed计算监控,这里相当于计算价格*数量,为啥我定义的num属性使用的时候要使用model.num(),因为ko.observable已经把它变为了一个函数了,需要具体了解的同学可以度娘下。

2、Knockout.js中的监控依赖属性DependentObservable

又是一张图来了,看看效果有差别吗,好像没有啥差别是吧
监控依赖属性
那还是来看代码吧,敲黑板了哦,看下model中的total呢?为啥没有了,还是计算了总价,这是我们使用了监控依赖属性,而且同时监控了两个DOM对象哦

<body>
<p>价格:1000</p><a>数量:</a><input type="text" data-bind='textinput:num' /><br /><br /><a>运费:</a><input type="text" data-bind='textinput:freight' /><br /><br /><a>总价:</a><a  data-bind='text: total'></a ><script type="text/javascript">var model={num:ko.observable(12),freight:ko.observable(20),};			model.total = ko.dependentObservable(function () {return 1000*model.num()+Number(model.freight());})ko.applyBindings(model);</script></body>

3、Knockout.js中的监控数组ObservableArray

老规矩先上图
ObservableArray

<body>
<a>商品类别无ID:</a><select data-bind="options:typeArrayoutID"></select><br /><br /><br /><a>商品类别:</a><select data-bind="options:typeArray,optionsText:'name'"></select><button id="addBtn">新增类别</button><script type="text/javascript">var typeArray=[{id:1,name:'电子商品'},{id:2,name:'日用品'},{id:3,name:'化妆品'}];var typeArrayoutID=["电子商品","日用品",'化妆品'];var model={typeArray:ko.observableArray(typeArray),typeArrayoutID:ko.observableArray(typeArrayoutID)};ko.applyBindings(model);$("#addBtn").bind('click',function () {model.typeArray.push({id:4,name:'电子商品11'});model.typeArrayoutID.push("电子商品11");})</script></body>

我们可以不再对select进行任何操作,只需要model里面的值就行了,是不是很酷
关于更多的Knockout知识,我们可以参见官方文档:https://knockoutjs.com/documentation/introduction.html

二、Cesium.knockout介绍及使用

上面说到,Cesium中的knockout与Knockoutjs(简称ko),不是完全一样的,但是功能大致一样,依然遵循MVVM模式,只要你理解了ko,那么使用Cesium.knockout将会轻松上手,接下来我们来看下Cesium.knockout的使用方法。

1、knockout中的监控属性getObservable

类似Knockout.js中的监控属性observable,这个属性就是用来监控属性变化的。
老规矩,先上一张效果图,看下Cesium.knockout实现的效果图。
改变飞机状态
接下来我们看下实现步骤:
1、定义viewModel
2、与DOM绑定,我们使用data-bind绑定了值(data-bind="value:scale)
3、使用Cesium.knockout.track绑定viewModel,监控viewModel中的属性(Cesium.knockout.track(viewModel))
4、与DOM元素绑定Cesium.knockout.applyBindings(viewModel, DOM元素)
5、使用Cesium.knockout.getObservable进行属性监控,对模型进行操作

看下改变飞机大小的具体的代码实现:

<body><div id="cesiumContainer"></div><div id='mytoolbar'><a>大小:</a><input type="range" min="1" max="20" data-bind="value:scale,valueUpdate: 'input'" /><a>方向:</a><input type="range" min="0" max="360" data-bind="value:orientation,valueUpdate: 'input'" /><a>位置:</a><input type="range" min="0" max="20" data-bind="value:positionsAdd,valueUpdate: 'input'" /></div><script type="text/javascript">var ssss=5;function onload(Cesium) {var viewer = new Cesium.Viewer('cesiumContainer');var viewModel = {scale: 5,orientation: 45,positionsAdd: 0};Cesium.knockout.track(viewModel);var positionstart = Cesium.Cartesian3.fromDegrees(101.80089882736969, 26.60700234866561, 1170);var orientation = Cesium.Transforms.headingPitchRollQuaternion(positionstart, new Cesium.HeadingPitchRoll(Cesium.Math.toRadians(viewModel.orientation), Cesium.Math.toRadians(0), Cesium.Math.toRadians(0)));var toolbar = document.getElementById('mytoolbar');Cesium.knockout.applyBindings(viewModel, toolbar);var modelAir = viewer.entities.add({id: "test",position: positionstart,orientation: orientation,model: {uri: 'data/Cesium_Air.gltf',scale: viewModel.scale,minimumPixelSize: 20,}});viewer.flyTo(modelAir);Cesium.knockout.getObservable(viewModel, "scale").subscribe(function(value) {modelAir.model.scale=Number(value);});Cesium.knockout.getObservable(viewModel, "orientation").subscribe(function(value) {modelAir.orientation=Cesium.Transforms.headingPitchRollQuaternion(positionstart, new Cesium.HeadingPitchRoll(Cesium.Math.toRadians(Number(value)), Cesium.Math.toRadians(0), Cesium.Math.toRadians(0)));;});Cesium.knockout.getObservable(viewModel, "positionsAdd").subscribe(function(value) {modelAir.position=Cesium.Cartesian3.fromDegrees(101.80089882736969+Number(value)/10000, 26.60700234866561+Number(value)/10000, 1170);});}</script></body>

2、knockout中的监控依赖属性DependentObservable

与Knockout.js相比Cesium.knockout一样的有监控依赖属性
改变颜色
如果我们希望在改变大小方向位置等信息的时候一起改变飞机的颜色,但是我们并没用在viewModel 对象中定义颜色的属性,如何解决呢?那么就可以使用DependentObservable。代码很简单,只有一句:

Cesium.knockout.dependentObservable(function () {modelAir.model.color= new Cesium.Color(Number(viewModel.scale)/255, Number(viewModel.orientation)/255, Number(viewModel.positionsAdd)/255, 1);})

3、knockout中的监控数组ObservableArray

和Knockout.js中使用方法一致,这里不再介绍了。

三、总结

Cesium.knockout对象与Knockout.js对象是不完全一样的,大部分相同但是也有很多不同的地方。可以理解为Cesium.knockout继承于Knockout.js,比如getObservable是Cesium.knockout独有的,ko没有,所以大家注意两者的的区别,建议不要混用,一个工程中使用一种足够解决问题了。

这篇关于SuperMap iClient3D for WebGL教程(Entity)-Knockout的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/745132

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom

前端技术(七)——less 教程

一、less简介 1. less是什么? less是一种动态样式语言,属于css预处理器的范畴,它扩展了CSS语言,增加了变量、Mixin、函数等特性,使CSS 更易维护和扩展LESS 既可以在 客户端 上运行 ,也可以借助Node.js在服务端运行。 less的中文官网:https://lesscss.cn/ 2. less编译工具 koala 官网 http://koala-app.

【Shiro】Shiro 的学习教程(三)之 SpringBoot 集成 Shiro

目录 1、环境准备2、引入 Shiro3、实现认证、退出3.1、使用死数据实现3.2、引入数据库,添加注册功能后端代码前端代码 3.3、MD5、Salt 的认证流程 4.、实现授权4.1、基于角色授权4.2、基于资源授权 5、引入缓存5.1、EhCache 实现缓存5.2、集成 Redis 实现 Shiro 缓存 1、环境准备 新建一个 SpringBoot 工程,引入依赖:

Windows环境利用VS2022编译 libvpx 源码教程

libvpx libvpx 是一个开源的视频编码库,由 WebM 项目开发和维护,专门用于 VP8 和 VP9 视频编码格式的编解码处理。它支持高质量的视频压缩,广泛应用于视频会议、在线教育、视频直播服务等多种场景中。libvpx 的特点包括跨平台兼容性、硬件加速支持以及灵活的接口设计,使其可以轻松集成到各种应用程序中。 libvpx 的安装和配置过程相对简单,用户可以从官方网站下载源代码

PHP APC缓存函数使用教程

APC,全称是Alternative PHP Cache,官方翻译叫”可选PHP缓存”。它为我们提供了缓存和优化PHP的中间代码的框架。 APC的缓存分两部分:系统缓存和用户数据缓存。(Linux APC扩展安装) 系统缓存 它是指APC把PHP文件源码的编译结果缓存起来,然后在每次调用时先对比时间标记。如果未过期,则使用缓存的中间代码运行。默认缓存 3600s(一小时)。但是这样仍会浪费大量C

Qt多语种开发教程

Qt作为跨平台的开发工具,早已应用到各行各业的软件开发中。 今天讲讲,Qt开发的正序怎么做多语言开发。就是说,你设置中文,就中文显示;设置英语就英文显示,设置繁体就繁体显示,设置发育就显示法语等。 开发环境(其实多语种这块根环境没太大关系):win10,Qt.5.12.10 一.先用QtCreator创建一个简单的桌面程序 1.工程就随便命名“LanguageTest”,其他默认。 2.在设计师

如何打造个性化大学生线上聊天交友系统?Java SpringBoot Vue教程,2025最新设计思路

✍✍计算机编程指导师 ⭐⭐个人介绍:自己非常喜欢研究技术问题!专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目:有源码或者技术上的问题欢迎在评论区一起讨论交流! ⚡⚡ Java实战 | SpringBoot/SSM Python实战项目 | Django 微信小程序/安卓实战项目 大数据实战项目 ⚡⚡文末获取源码 文章目录