当前位置:首页>> iPhone wap浏览器之界面架构篇

iPhone wap浏览器之界面架构篇

发布时间:2016-03-18作者:智汇小新

  在笔者的上篇文章《自己动手写iPhone wap浏览器之BSD Socket引擎篇》中已经成功解析出来了wml页面中的tag,如果读者仔细的话可能会看到里面中文的tag显示为乱码,这是因为在iPhone上默认的中文编码格式是UTF-8,而通过BSD Socket请求过来的是ASCII码,所以需要通过转换为UTF-8格式,如下:

  [[NSString alloc] initWithBytes:aChild-》Value() length:strlen(aChild-》Value()) encoding:NSUTF8StringEncoding]

  经过转换编码之后,在屏幕上显示的打印内容如下:

  parse xml succeed

  aChild value = STATUS OK

  aChild value = card

  TiXmlNode::ELEMENT name = title, attr value = 百度一下,你就知道

  aChild value = p

  aChild value = img

  TiXmlNode::ELEMENT name = src, attr value = /r/wise/wapsearchindex/logoindexsmall.gif

  TiXmlNode::ELEMENT name = alt, attr value = 百度首页

  aChild value = br

  aChild value = input

  TiXmlNode::ELEMENT name = name, attr value = word

  TiXmlNode::ELEMENT name = emptyok, attr value = true

  aChild value = br

  aChild value = anchor

  aChild value = 搜网页

  TiXmlNode::TEXT Value = 搜网页

  接下来的任务就是渲染这些解析出来的tag并显示在界面上了,本篇里笔者重点讲述如果搭建一个可扩展的、健壮的界面架构。

  在所有平台的界面架构中,笔者一直推崇MVC,MVC的着重点在于把界面显示和数据处理分离开来以提供可扩展的界面架构平台。基于这个思想,笔者建立了如下的架构图:

  

  图1.Tag界面架构图

  在Xml模块处理完xml数据并提取出tag后,交给CXmlControl进行处理,CXmlControl在这里充当Control的角色,它负责在处理完tag(标签)后生成相应的消息以显示在界面上。

  其中CXmlControl继承自UIView类,它负责显示界面并响应用户的按键消息,而具体的逻辑处理则是在CXmlControlImpl类中进行的,CXmlControlImpl这个类负责管理生成的tag(标签)以及tag(标签)的界面Layout(布局),如下:

  @class CXmlControlImpl;

  @interface CXmlControl : UIView {

  @public

  CXmlControlImpl* iImpl;

  }

  -(void) addElements:(CXmlElementImpl*)iElemntAdded;

  -(CXmlElement*) InsertContent:(CXmlElement*)aTarget aPosition:(NSInteger)aPosition aSource:(const NSString*)aSource aFlags:(NSInteger)aFlags;

  -(CXmlElement*) AppendContent:(const NSString*)aSource aFlags:(NSInteger)aFlags;

  -(void) Refresh;

  -(void) RefreshAndDraw;

  -(void) ClearContent;

  -(void) RemoveElement:(CXmlElement*)aElement;

  -(CXmlElement*) Element:(const NSString*)aId aIndex:(NSInteger)aIndex;

  -(CXmlElement*) ElementByTag:(const NSString*)aTagName aIndex:(NSInteger)aIndex;

  -(CXmlElement*) FocusedElement;

  -(void) SetFocusTo:(CXmlElement*)aElement;

  -(void) ScrollToView:(CXmlElement*)aElement;

  -(CXmlElement*) Body;

  -(void) SetEventObserver:(id《MXmlCtlEventObserver》)aObserver;

  -(CXmlElementImpl*) Impl;

  -(CGContextRef) SystemGc;

  -(void) Draw:(const CGRect)aRect;

  -(CWritableBitmap*) OffScreenBitmap;

  -(void) SetOffScreenBitmap:(CWritableBitmap*)aBitmap;

  -(void) DrawOffscreen;

  -(void) touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event;

  -(void) touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event;

  -(void) touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event;

  @end

  Tag(标签)类的基类为CXmlElement,它抽象了标签的基本属性和操作,在每一个派生自此基类的tag(标签)类如CXmlTextElement、CXmlImgElement中都维护一个全局的布局类CHcMeasureStatus,每一个tag(标签)类都负责自己的布局和自己的绘制操作,完成布局操作和绘制操作后为改变CHcMearuseStatus的状态和属性并传递给CXmlControl类。

公司简介

宜科(天津)电子有限公司是中国工业自动化的领军企业,于2003年在天津投资成立,销售和服务网络覆盖全国。作为中国本土工业自动化产品的提供商和智能制造解决方案的供应商,宜科在汽车、汽车零部件、工程机械、机器人、食品制药、印刷包装、纺织机械、物流设备、电子制造等诸多领域占据领先地位。宜科为智慧工厂的整体规划实施提供自系统层、控制层、网络层到执行层自上而下的全系列服务,产品及解决方案涵盖但不局限于云平台、MES制造执行系统、工业现场总线、工业以太网、工业无线通讯、机器人及智能设备组成的自动化生产线、自动化电气控制系统集成、智能物流仓储系统等,以实现真正智能化的生产制造,从而带来生产力和生产效率的大幅提升,以及对生产灵活性和生产复杂性的管理能力的大幅提升。多年来,宜科以创新的技术、卓越的解决方案和产品坚持不懈地为中国制造业的发展提供全面支持,并以出众的品质和令人信赖的可靠性、领先的技术成就、不懈的创新追求,在业界独树一帜。帮助中国制造业转型升级,加速智能制造进程,成为中国工业4.0智慧工厂解决方案当之无愧的践行者。

更多详情>>

联系我们

  • 联系人:章清涛
  • 热线:18611695135
  • 电话:
  • 传真:
  • 邮箱:18210150532@139.com

Copyright © 2015 ilinki.net Inc. All rights reserved. 智汇工业版权所有

电话:010-62314658 邮箱:service@ilinki.net

主办单位:智汇万联(北京)信息技术有限公司

京ICP备15030148号-1