zoukankan      html  css  js  c++  java
  • iOS Multiview Applications

    1 View

    1.1 简介

          UIView表示屏幕上的一块矩形区域,它在App中占有绝对重要的地位,因为IOS中几乎所有可视化控件都是UIView的子类。负责渲染区域的内容,并且响应该区域内发生的触摸事件。

    UIView的功能 1.管理矩形区域里的内容2.处理矩形区域中的事件3.子视图的管理 4.还能实现动画 UIView的子类也具有这些功能

    图 1 UIView及子类继承关系

    1.2 三个结构体 CGPoint、CGSize、CGRect

    1)CGPoint  

    struct CGPoint { 
          CGFloat x; 
          CGFloat y; 
    }; 
    typedef struct CGPoint CGPoint;看到这个想必你已经懂了,不再解释。 

     

    2) CGSize

    struct CGSize { 
        CGFloat width; 
        CGFloat height; 
    }; 
    typedef struct CGSize CGSize; 不解释。

    3) CGRect

    struct CGRect { 
         CGPoint origin; //偏移是相对父视图的 
         CGSize size; 
    }; 
    typedef struct CGRect CGRect;同样 不解释。 

    这三个结构体均在一个头文件里:CGGeometry.h

    1.3 视图的最基本属性

    frame和center都是相对于父视图的,bounds是相对于自身的

    • frame:是CGRect frame的origin是相对于父视图的左上角原点(0,0)的位置,改变视图的frame会改变center
    • center:是CGPoint指的就是整个视图的中心点,改变视图的center也会改变frame
    • bounds:是CGRect是告诉子视图本视图的原点位置(通俗的说就是,子视图的frame的origin与父视图的bounds的origin的差,就是子视图相对于父视图左上角的位置,如果结果为负,则子视图在父视图外)

    图 2

    1.4 界面元素:window(窗口)、视图(view)

         UIWindow是一种特殊的UIView,通常在一个app中只会有一个UIWindow。iOS程序启动完毕后,创建的第一个视图控件就是UIWindow,接着创建控制器的view,最后将控制器的view添加到UIWindow上,于是控制器的view就显示在屏幕上了。其中这个view称为根视图或是初始化视图,一般也只有一个。

    2 创建View对象的方式

         有两种方式创建view对象,Interface Builder和Programmatically。

    2.1 Interface Builder

         最简单的方式是使用图形界面的Interface Builder方法,通过这种方式能够从对象库中拖拽一个view对象到interface,安排它们的层次结构并对其配置,同时能够将这些view连接到代码中,从而实现它们的行为。可以参考《Interface Builder User Guide》文档。若创建完view后,可以在代码中获得view对象的controller,如swift实现为:

    var blue:blueViewController! 
    blue = storyboard?.instantiateViewControllerWithIdentifier("blue"as! blueViewController; // blue为标识符  

    2.2 Programmatically

          还可以通过程序进行创建,其中可以使用标准的allocation/initialization模式。默认的initialization方法是initWithFrame,可以该方法初始化view尺寸和相对位置。比如object c实现为:

    CGRect viewRect = CGRectMake(00100100); 
    UIView* myView = [[UIView alloc] initWithFrame:viewRect]; 

    3 创建和管理subviews的层次结构

    管理视图的层次结构对应用开发来说是一个很重要的部分,对视图的组织即影响视图的显示,又影响事件是如何响应的。如图 3所示的Clock应用。

    图 3

    3.1 增加和移除子视图(subview)

    一个UIView里面可以包含许多的Subview(其他的UIView),而这些 Subview 彼此之间是有所谓的阶层关系,这有点类似绘图软体中图层的概念,其中第0层是在最低下,即层数越高越在上层,从而上层的视图会遮住下层的视图。如所示表 1时UIView的常用方法。

    表 1 UIView常用方法

    Method

    usage

    addSubview

    这个是父视图的方法,通过这个方法能够将一个Subview添加到父视图的subview列表的尾部;

    insertSubview

    这个是父视图方法,可以将子视图插入父视图subview列表的指定位置;

    removeFromSuperview

    这个是子视图方法,通过它能够将子视图从父视图的subview列表中移除;

    bringSubviewToFront

    这个是父视图方法,将Subview往前移动一个图层(与它的前一个图层对调位置);

    sendSubviewToBack

    这个是父视图方法,将Subview往后移动一个图层(与它的后一个图层对调位置);

    exchangeSubviewAtIndex

    这个是父视图方法,交互子视图的位置。

    如下的程序是在父视图控制器中实现两个子视图之间的切换:    

     1 func viewMove(from:UIViewController!,to:UIViewController!){ 
     2     let subViewNun = self.view.subviews.count //为视图的层数,待会将to视图放在最上层。 
     3     if from != nil{ 
     4     from!.willMoveToParentViewController(nil); 
     5     from!.view.removeFromSuperview();//调用子视图方法,从父视图中移除子视图。 
     6     from!.removeFromParentViewController(); 
     7     } 
     8     if to != nil{ 
     9             to. view.frame = view.frame//设置子视图的框架与父视图一样 
    10     self.addChildViewController(to!)//将子视图控制器添加到父视图的subview controller列表中 
    11     self.view.insertSubview(to!.view, atIndex: subViewNun)//将子视图添加到父视图的subview列表中 
    12     to!.didMoveToParentViewController(self) //调用子视图控制器方法,表明视图图发生变化了 
    13     } 
    14 } 
     

           当添加一个subview到另一个view中,UIKit即会通知父视图,又会通知子视图发生视图内容发生变化了。所以如果实现了定制的view,那么可以通过重载willMoveToSuperview, willMoveToWindow, willRemoveSubview, didAddSubview, didMoveToSuperview或didMoveToWindow方法来拦截这些消息,可以通过这些消息来更新相关的视图层次结构的状态或信息。

    3.2 隐藏视图

         为了隐藏视图的可见性,可以通过将"hidden"属性设置为yes,或者是将"alpha"属性值设置为0.0。被隐藏的视图不会再从系统中接收到触摸事件,当隐藏的视图还是会参加一些布局操作。其中若需要在隐藏时设置动画操作,那么只能通过修改alpha属性,而不能修改hidden属性,因为hidden不是animation属性。

         Important:如果要对第一响应者进行隐藏操作时,那么系统不会取消该视图的第一响应。所以当有消息到来时,仍然会把消息传递给这个被隐藏的视图,若要取消其事件的接收,需要手动进行取消。

    3.3 转换、放大和旋转视图

         暂无

    3.4 转换坐标

        暂无    

    参考文献:view Programming Guide for iOS

    4 ViewController

    4.1 简介

          在mvc设计模式中,controller对象提供特定的逻辑,负责连接应用程序的data和view,而且将data展示给用户。在ios应用程序中,view controller是一个特殊类型的controller对象,可以使用它来展示和管理一系列view,同时能够应用它从一个屏幕转到另一个屏幕。

          每种UIView都可以指定一个UIViewController类或子类对其进行管理,当然也不是每种UIView都需要UIViewController类,其中将需要UIViewController的UIView称作content view(内容视图),因为这些content view是应用程序的主要容器。

          在storyboard中将UIView和UIViewController合称为scene,并且在storyboard中不能独立存在UIView对象或组件,而是需要将UIView组件放置在UIViewController内(可放置多个),但是在xib文件中却是可以独立存在的。也就是说在content view中可以放置普通的UIView和容器类型的UIView,这样将放置在content view的UIView称为子view,而将content view称作父view。在content view中的子view是于图像的层次结构进行组织的,即上层的view可能会阻挡下层view的视线。如图 1所示的view层次结构,其中RootView需要放置在UIViewController中。

    图 4s

    View controller类型:

    • custom view controller:这是一种用于表示屏幕显示内容的控制器对象。
    • container view controller:这是一种特殊的view controller对象,它负责管理其它view controller对象,并定义view之间的导航关系。比navigation, tab bar和split view controllers
    • modal view controller:这既是custom view controller,又是container view controller,

    图 5

    4.2 常用方法

    表 2

    Method

    usage

    addChildViewController

    向视图控制器容器中添加子视图控制器;

    removeFromParentViewController

    向视图控制器容器中添加子视图控制器;

    transitionFromViewController

    交换两个子视图控制器的位置;

    willMoveToParentViewController

    从视图控制器容器中被移动到另外一个视图控制器,如果没有父视图控制器,将为nil;

    didMoveToParentViewController

    当从一个视图控制容器中添加或者移除viewController后,该方法被调用。

    参考文献:

        《Beginning iPhone Development with Swift Exploring the iOS SDK-Apress(2014)》Chapter6

        http://blog.csdn.net/chengyingzhilian/article/details/7894276

        http://www.gowhich.com/blog/543

    Cheng

           工具栏可以包含按钮和其他一些控件,但这些项并不是互斥的。

  • 相关阅读:
    PHP开发环境的搭建
    ios请求服务器数据 ASIHTTPRequest
    Android 调用GPS
    C语言学习规划
    weifenluo与notifyIcon小细节
    初涉Ribbon界面简单编程——图书管理系统——基于MFC+vs2010+win7。
    多线程编程之二——MFC中的多线程开发(转)
    类 StringTokenizer
    表单中Readonly和Disabled的区别
    研究了下Ajax,写了个处理Ajax函数
  • 原文地址:https://www.cnblogs.com/huliangwen/p/5004791.html
Copyright © 2011-2022 走看看