`
buliedian
  • 浏览: 1234773 次
  • 性别: Icon_minigender_2
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

基于模型的可复用移动web应用程序开发-画出一个iPhone应用

阅读更多

基于模型的移动web应用程序开发

软件行业的精英们一直在寻找提高软件生产力的银弹。提高生成力的核心在于重用。这包含代码的重用、设计的重用。用户有很多相似的需求,针对这些需求提取出一些基本的模型元素从而可以在领域中复用。面向对象、基于模板、基于模型和基于框架的开发方法给行业带来了希望。

如果您正准备开发一个交友社区客户端的移动应用程序,需要覆盖主流的移动平台,比如iPhoneAndroidWindows PhoneSymbian以及大量的山寨系统,那么你可以有如下的选择:

1、 招聘一个团队,每位工程师有不同平台的开发经验。

2、 Soho,自学所有的平台SDK和语言,自行开发

3、 开发一个移动web应用,匹配主流的浏览器

选择1的前提是您不差钱。选择2是您对自己的能力充分信任,但有可能会因为进度缓慢而丧失市场良机,也可能因为后续无力适配变化多端的机型和不同版本的SDK而无奈终止维护,这样的故事比比皆是。那么你可能会自然的选择3来降低学习成本、研发成本以及加快开发进度。但是移动web应用在带来适配方便的同时,也丧失了本地应用程序的更为友好华丽的界面观感以及访问本地资源的权利。另外如果您还想把移动应用的开发复用到PC领域,就需要考虑更多的移植策略。一个可行的解决方案就是基于模型的开发。模型是平台无关的需求抽象。和平台相关的代码层面交给框架根据环境配置、用户选项来自动生成,然后针对特定的领域和客户要求,进行再加工和编码优化。这解决了3个方面的问题:

1、 解决了平台之间移植复用的问题。首先选取通用的数据和流程模型元素来构架系统,然后调用合适的代码生成器来产生针对特定平台的工程。

2、 解决了设计标准和编码规范的问题。由于代码框架是由生成器产生。因此使用同样的建模描述方式就可以保持代码风格的一致性和代码规范性。

3、 支持更为敏捷的原型开发,便于客户理解系统。

理论看上去很美,然而要构造这样的基于模型的开发环境并投入到实际的软件生产过程中去,则并非那么容易。我了解到的EMF(基于Eclipse的模型框架)http://www.eclipse.org/modeling/emf/在这方面做了很多工作。而国内少有听闻有类似的工具在应用,尽管在鄙人看来这是一个逐渐明朗的技术趋势。

现在停止大话连篇,回到移动应用程序开发的主题上来,这里我要举一个非常实用的例子来说明上述的一些观点。让我们从头体验一下在现实工作中如何使用基于模型的开发方式来快速开发移动web应用程序。在这里我们将开发一个Twitter客户端的iPhone应用程序。看到iPhone应用程序,您可能会犹豫。难道我要为此去购买一个Mac机,我是不是还要先申请加入苹果开发人员计划,是不是还要买个iPhone?很幸运,在我举的这个例子中,你只要有PC机和浏览器即可。如果您有过iPhone开发经验,那么应该知道使用XCode构建一个显示Twitter最新消息的客户端,基本上需要做如下几件事情:

l 设计界面

l 连接元素

l 建立HTTP连接

l 发送请求、读取资源

l 解析JSON数据

l 添加用户图标

l 更新界面数据

根据您对XCode工具、iPhone SDK以及Objective C语言的掌握程度,可能会花费几天或几个小时不等的时间来完成这个任务。

那么让我们试试下面基于模型的方法是不是给我们带来一些Amazing Magic

首先您得下载必要的开发工具Tersus Studio windows版本:http://www.tersus.com/#Id=240

这是一个基于Eclipse的开源开发平台。

第一步:基础设置


1. 创建一个新Tersus project:

o 选择File -> New -> Tersus Project.

o 输入Project name: Twitter

o 选择Template: iPhone Application

o 点击Finish 按钮

2. 在模型编辑器(即中间的主窗口)中,双击放大到 <iPhone View>/Body.

3. 右键点击Body --> Add Element: Scroll Pane. 名字修改为: Top Trends Screen.

4. 放大到 Top Trends Screen.

5. 右键点击Top Trends Screen -->Add Element: List.

这样我们就创建了一个包含一个列表控件的带滚动条的<iPhone View>。注意该工程Outline窗口中有两个视图,分别是<Desktop View><iPhone View>,这里因为我们创建的是iPhone应用,因此我们仅关注<iPhone View>,展开它可以看到刚才添加的元素。保存工程并运行它(焦点需要在模型编辑器中)。浏览器将会自动启动。默认情况为打开https://localhost:8080/twitter,我们在后面加上/iphone.html。也就是https://localhost:8080/twitter/iphone.html。这样将会出现如下iPhone空白界面:

第二步:读取Twitter数据


  1. 在模型编辑器中,放大到<iPhone View>/Body/Top Trends Screen/List.
  2. 从左边palette窗口的Basic部分拖动一个ActionTop Trends Screen. 取名为Init.
  3. 建模Top Trends Init 动作:
    • 放大到Init.
    • palette窗口的Basic部分拖拉一个Service. 取名Get Top Trends.
    • 添加一个exit(灰色小箭头)到Get Top Trends.
    • Display Actions 部分拖拉一个Alert.
    • Get Top TrendsexitAlert trigger(绿色小箭头)创建一个flow. Init模型看起来如下:
    • 建模Get Top Trends服务:
      • Constants部分拖拉一个Text常量。数值为'http://search.twitter.com/trends.json'。名字改为Trends URL.
      • Basic部分拖拉一个Action,取名Download URL. 给这个action添加一个trigger和一个exit
      • Trends URL constant Download URLtrigger创建一个flow
      • Download URLexitGet Top Trendsexit创建一个flow。这个服务现在看起来应该像下面这样:
      • 建模Download URL 动作:
        • Miscellaneous部分拖拉一个Read Resource.
        • Text部分拖拉一个Binary to Text 从中删除<Encoding> trigger
        • Download URL triggerRead Resource <URL> trigger创建一个flow
        • Read Resource<Content> exitBinary to Text<Binary> trigger创建一个flow
        • Binary to TextexitDownload URLexit创建一个flowDownload URL 看起来如下:
  • 保存工程
  • 切换回浏览器窗口。应该会自动更新。
  • 你将会看到一个Alert窗口,显示从Twitter获取到的JSON格式数据。

注:如果您在国内,那么因为社会和谐的原因,你将得到无法访问https://search.twitter.com/trends.json URL的错误。不过不要担心,稍后会给出解决方法。你可以暂时把Twitter searchURL改为Google mapURL来体验上述过程。(关于如何调用Google map您可以参考我以前的文章)

第三步:以iPhone的风格显示数据


  1. 在模型编辑器中,放大到<iPhone View>/Body/Top Trends Screen/List.
  2. 右键点击List --> Add Element: Content Item.
  3. 建模Init 动作:
  • 放大到Init Action.
  • Get Top Trends添加一个exit. 命名为Parsed Data。设置其Reptetive属性。(选中exit对象,点击右键)
  • 右键点击Init --> Add Ancestor Reference: 选择Top Trends Screen.
  • Get Top Trendsrepetitive exit(重叠的灰色小箭头)到Content Item (Scrollable Pane/List/Content Item)元素的exit创建一个flow
  • 删除到Alertflow
  • 到目前为止Init 动作应该看起来如下:
  • 删除Alert 元素。
  1. 建模Get Top Trends:
  • Miscellaneous部分拖拉一个Parse JSON.
  • Download URL exitParse JSON<JSON Text> trigger创建一个flow
  • Data Types部分拖拉一个Data Structre。取名: Top Trends DS.
  • 从同样的部分拖拉下面这些元素到Top Trends DS 并如下命名:

as_of: 类型: Text.

trends: 类型: Data Dtructure; Reptetive.

name: 类型: Text.

url: 类型: Text.

  • Parse JSON <Value> exit Top Trends DS 创建一个flow
  • Basic部分拖拉一个Action。取名Convert to Content Item.
  • 为这个动作添加一个trigger 和一个exit。设置动作为repetitive
  • Top Trends DS/trends Convert to Content Item trigger创建一个flow
  • Convert to Content Item exit Get Top Trends repetitive exit (Prased Data) 创建一个flow.
  • Get Top Trends 服务模型看起来应该如下:

  • 建模'Convert to Content Item':
    • 右键点击Convert to Content Item trigger并选择Show in Repository Explorer. Repository Explorer 中拖拉trends 数据结构到模型编辑器中的Convert to Content Item 动作中。
    • Convert to Content Item trigger trends 创建一个flow
    • 同样的: 右键点击Convert to Content Item exit 并选择 Show in Repository Explorer. Repository Explorer 拖拉Content ItemConvert to Content 动作里. Content Item Convert to Content Item exit 创建一个flow
    • Constants部分拖拉一个Text 常量,设置数值为: Twitter48.png.
    • "Twitter48.png" constant Content Item/Icon/<Path>创建一个flow
    • trend/name Content Item/Content Holder/Title Text/<Value>创建一个flow
    • trend/url Content Item/Content Holder/Content Text/<Value>创建一个flow
    • Convert to Content Item 看起来应该如下:

  1. 添加图像:
  • 保存工程.
  • 切换回浏览器,应该会自动刷新。

如果您的所在地能够访问twitter网站,您将看到如下页面:

如果您有幸在和谐的国度里享受纯净的生活,还想见到如上叽叽喳喳的消息界面,那么您将需要付出一些额外的努力:

1、 安装freegate软件。请Google之。

2、 设置Tersus Studio http代理:Windows->Preference->General->Network Connections

到此为此,您没有写一行代码!您的工作台上只有如下的模型图:

您再回头计算一下花费了多长时间。我第一次花了2个小时。这是在我不熟悉其快捷操作和工具界面的情况完成的。熟练的工程师会怎么样?也许只要半个小时!

好吧,我们用鼠标拖来拖去完成了这个神奇的魔术。而魔术的内幕则有待您自行体会和思考了。这个平台是开源的,所以能够理解和使用到什么程度,不会有不可逾越的障碍。您或许还想把这个模型应用到AndroidBlackberycolor: #1

分享到:
评论

相关推荐

    电子商务之价格优化算法:梯度下降:机器学习在价格优化中的角色.docx

    电子商务之价格优化算法:梯度下降:机器学习在价格优化中的角色.docx

    ToadforOracle与Oracle数据库版本兼容性教程.docx

    ToadforOracle与Oracle数据库版本兼容性教程.docx

    browser360-cn-stable-13.3.1016.4-1-amd64.deb

    360浏览器银河麒麟版 for X86 适配兆芯 / 海光 / intel / AMD CPU

    基于React.js和Material-UI个人作品集网站模板(附源码+说明文档).zip

    使用React.js构建,提供多种主题可供选择,并且易于定制。该项目旨在帮助开发者和自由职业者创建自己的个性化投资组合。 主要功能点 多种主题可供选择,包括绿色、黑白、蓝色、红色、橙色、紫色、粉色和黄色 易于定制,可以在src/data文件夹中更新个人信息 包含主页、关于、简历、教育、技能、经验、项目、成就、服务、推荐信、博客和联系等多个部分 支持通过Google表单收集联系信息 提供SEO优化建议 支持多种部署方式,如Netlify、Firebase、Heroku和GitHub Pages 技术栈主要 React.js Material-UI Axios React-fast-marquee React-helmet React-icons React-reveal React-router-dom React-router-hash-link React-slick Slick-carousel Validator

    中小型企业财务管理系统 SSM毕业设计 附带论文.zip

    中小型企业财务管理系统 SSM毕业设计 附带论文 启动教程:https://www.bilibili.com/video/BV1GK1iYyE2B

    apsw-3.38.5.post1-cp39-cp39-win_amd64.whl.rar

    python whl离线安装包 pip安装失败可以尝试使用whl离线安装包安装 第一步 下载whl文件,注意需要与python版本配套 python版本号、32位64位、arm或amd64均有区别 第二步 使用pip install XXXXX.whl 命令安装,如果whl路径不在cmd窗口当前目录下,需要带上路径 WHL文件是以Wheel格式保存的Python安装包, Wheel是Python发行版的标准内置包格式。 在本质上是一个压缩包,WHL文件中包含了Python安装的py文件和元数据,以及经过编译的pyd文件, 这样就使得它可以在不具备编译环境的条件下,安装适合自己python版本的库文件。 如果要查看WHL文件的内容,可以把.whl后缀名改成.zip,使用解压软件(如WinRAR、WinZIP)解压打开即可查看。 为什么会用到whl文件来安装python库文件呢? 在python的使用过程中,我们免不了要经常通过pip来安装自己所需要的包, 大部分的包基本都能正常安装,但是总会遇到有那么一些包因为各种各样的问题导致安装不了的。 这时我们就可以通过尝试去Python安装包大全中(whl包下载)下载whl包来安装解决问题。

    电子商务之价格优化算法:线性回归:价格优化策略实施.docx

    电子商务之价格优化算法:线性回归:价格优化策略实施.docx

    工业数字化转型的关键技术及其应用场景解析

    内容概要:报告详细介绍了企业数字化转型的驱动因素、数字化转型方案分类及其应用场景,重点关注了云计算、超连接、数字孪生、人工智能、分布式账本、增材制造、人机接口、数据共享、工业物联网等关键技术。这些技术不仅支持了企业的运营效率提升和业务模式创新,也为实现更快、更开放、更高效的数字化转型提供了支撑。报告最后提出了企业实施数字化转型的六个步骤。 适合人群:企业高级管理人员、技术人员、咨询顾问,以及对工业数字化转型感兴趣的读者。 使用场景及目标:帮助企业制定和实施数字化转型策略,优化运营模式,提升业务效率,增强市场竞争力。同时,也可作为政府部门、研究机构和行业协会的参考文献。 其他说明:报告中提到的关键技术及其应用场景对企业数字化转型具有重要的指导意义,特别是对于那些希望通过数字化转型实现业务创新和升级的企业。

    基于java的线上选课系统的设计与实现答辩PPT.pptx

    基于java的线上选课系统的设计与实现答辩PPT.pptx

    原版aggdraw-1.3.15-cp311-cp311-win_arm64.whl-下载即用直接pip安装.zip

    安装前的准备 1、安装Python:确保你的计算机上已经安装了Python。你可以在命令行中输入python --version或python3 --version来检查是否已安装以及安装的版本。 个人建议:在anaconda中自建不同python版本的环境,方法如下(其他版本照葫芦画瓢): 比如创建python3.8环境,anaconda命令终端输入:conda create -n py38 python==3.8 2、安装pip:pip是Python的包管理工具,用于安装和管理Python包。你可以通过输入pip --version或pip3 --version来检查pip是否已安装。 安装WHL安装包 1、打开命令行(或打开anaconda命令行终端): 在Windows上,你可以搜索“cmd”或“命令提示符”并打开它。 在macOS或Linux上,你可以打开“终端”。 2、cd到whl文件所在目录安装: 使用cd命令导航到你下载的whl文件所在的文件夹。 终端输入:pip install xxx.whl安装即可(xxx.whl指的是csdn下载解压出来的whl) 3、等待安装完成: 命令行会显示安装进度,并在安装完成后返回提示符。 以上是简单安装介绍,小白也能会,简单好用,从此再也不怕下载安装超时问题。 使用过程遇到问题可以私信,我可以帮你解决! 收起

    电子商务之价格优化算法:贝叶斯定价:贝叶斯网络在电子商务定价中的应用.docx

    电子商务之价格优化算法:贝叶斯定价:贝叶斯网络在电子商务定价中的应用.docx

    IMG_20241105_235746.jpg

    IMG_20241105_235746.jpg

    基于java的毕业设计选题系统答辩PPT.pptx

    基于java的毕业设计选题系统答辩PPT.pptx

    专升本考试资料全套.7z

    专升本考试资料全套.7z

    Trustwave DbProtect:数据库活动监控策略制定.docx

    Trustwave DbProtect:数据库活动监控策略制定.docx

    VB程序实例-CD-ROM开关.zip

    基于VB的程序实例,可供参考学习使用

    课设毕设基于SpringBoot+Vue的教育资源共享平台源码可运行.zip

    本压缩包资源说明,你现在往下拉可以看到压缩包内容目录 我是批量上传的基于SpringBoot+Vue的项目,所以描述都一样;有源码有数据库脚本,系统都是测试过可运行的,看文件名即可区分项目~ |Java|SpringBoot|Vue|前后端分离| 开发语言:Java 框架:SpringBoot,Vue JDK版本:JDK1.8 数据库:MySQL 5.7+(推荐5.7,8.0也可以) 数据库工具:Navicat 开发软件: idea/eclipse(推荐idea) Maven包:Maven3.3.9+ 系统环境:Windows/Mac

    基于Thinkphp5框架的Java插件设计源码

    该源码项目是一款基于Thinkphp5框架的Java插件设计,包含114个文件,其中Java源文件60个,PNG图片32个,XML配置文件7个,GIF图片7个,Git忽略文件1个,LICENSE文件1个,Markdown文件1个,Xmind文件1个,Idea项目文件1个,以及JAR文件1个。

    数据库开发和管理最佳实践.pdf

    数据库开发和管理最佳实践.pdf

    课设毕设基于SpringBoot+Vue的农场投入品运营线上管理系统源码可运行.zip

    本压缩包资源说明,你现在往下拉可以看到压缩包内容目录 我是批量上传的基于SpringBoot+Vue的项目,所以描述都一样;有源码有数据库脚本,系统都是测试过可运行的,看文件名即可区分项目~ |Java|SpringBoot|Vue|前后端分离| 开发语言:Java 框架:SpringBoot,Vue JDK版本:JDK1.8 数据库:MySQL 5.7+(推荐5.7,8.0也可以) 数据库工具:Navicat 开发软件: idea/eclipse(推荐idea) Maven包:Maven3.3.9+ 系统环境:Windows/Mac

Global site tag (gtag.js) - Google Analytics