coderTomato.github.io/uiview at master · coderTomato/coderTomato.github.io · GitHub
Skip to content

Latest commit

 

History

History

Folders and files

<!DOCTYPE HTML>
<html lang="en-US" >
    
    <head>
        
        <meta charset="UTF-8">
        <title>UIView | Mou</title>
        <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
        <meta name="description" content="">
        <meta name="generator" content="GitBook 1.0.3">
        <meta name="HandheldFriendly" content="true"/>
        <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
        <meta name="apple-mobile-web-app-capable" content="yes">
        <meta name="apple-mobile-web-app-status-bar-style" content="black">
        <link rel="apple-touch-icon-precomposed" sizes="152x152" href="../gitbook/images/apple-touch-icon-precomposed-152.png">
        <link rel="shortcut icon" href="../gitbook/images/favicon.ico" type="image/x-icon">
        
    
    
    
    <link rel="next" href="../jiugongge/README.html" />
    
    
    <link rel="prev" href="../base/README.html" />
    

        
    </head>
    <body>
        
        
<link rel="stylesheet" href="../gitbook/style.css">


        
    <div class="book"  data-level="2" data-basepath=".." data-revision="1462863912916">
    

<div class="book-summary">
    <div class="book-search">
        <input type="text" placeholder="Type to search" class="form-control" />
    </div>
    <ul class="summary">
        
    	
    	
    	

        

        
    
        
        <li class="chapter " data-level="0" data-path="index.html">
            
                
                    <a href="../index.html">
                        <i class="fa fa-check"></i>
                        
                         Markdown语法
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="1" data-path="base/README.html">
            
                
                    <a href="../base/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>1.</b>
                        
                         base
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter active" data-level="2" data-path="uiview/README.html">
            
                
                    <a href="../uiview/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>2.</b>
                        
                         UIView
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="3" data-path="jiugongge/README.html">
            
                
                    <a href="../jiugongge/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>3.</b>
                        
                         jiugongge
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="4" data-path="uiscrollview/README.html">
            
                
                    <a href="../uiscrollview/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>4.</b>
                        
                         UIScrollView
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="5" data-path="uitableview/README.html">
            
                
                    <a href="../uitableview/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>5.</b>
                        
                         UITableView
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="6" data-path="autolayout/README.html">
            
                
                    <a href="../autolayout/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>6.</b>
                        
                         autolayout
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="7" data-path="map/README.html">
            
                
                    <a href="../map/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>7.</b>
                        
                         map
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="8" data-path="notification/README.html">
            
                
                    <a href="../notification/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>8.</b>
                        
                         notification
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="9" data-path="nstimer/README.html">
            
                
                    <a href="../nstimer/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>9.</b>
                        
                         nstimer
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="10" data-path="oc/README.html">
            
                
                    <a href="../oc/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>10.</b>
                        
                         OC
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="11" data-path="rac/README.html">
            
                
                    <a href="../rac/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>11.</b>
                        
                         rac
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="12" data-path="review1/README.html">
            
                
                    <a href="../review1/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>12.</b>
                        
                         review1
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="13" data-path="review2/README.html">
            
                
                    <a href="../review2/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>13.</b>
                        
                         review2
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="14" data-path="audio/README.html">
            
                
                    <a href="../audio/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>14.</b>
                        
                         audio
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="15" data-path="twocode/README.html">
            
                
                    <a href="../twocode/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>15.</b>
                        
                         twocode
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="16" data-path="memory/README.html">
            
                
                    <a href="../memory/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>16.</b>
                        
                         memory
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="17" data-path="bluetooth/README.html">
            
                
                    <a href="../bluetooth/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>17.</b>
                        
                         bluetooth
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="18" data-path="touchid/README.html">
            
                
                    <a href="../touchid/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>18.</b>
                        
                         touchid
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="19" data-path="uiviewcontroller/README.html">
            
                
                    <a href="../uiviewcontroller/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>19.</b>
                        
                         UIViewController
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="20" data-path="delegate_kvo/README.html">
            
                
                    <a href="../delegate_kvo/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>20.</b>
                        
                         delegate kvo
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="21" data-path="datasave/README.html">
            
                
                    <a href="../datasave/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>21.</b>
                        
                         dataSave
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="22" data-path="pickerview/README.html">
            
                
                    <a href="../pickerview/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>22.</b>
                        
                         pickerView
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="23" data-path="quartz2d/README.html">
            
                
                    <a href="../quartz2d/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>23.</b>
                        
                         quartz2D
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="24" data-path="uitextfield/README.html">
            
                
                    <a href="../uitextfield/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>24.</b>
                        
                         UITextField
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="25" data-path="uidynamic/README.html">
            
                
                    <a href="../uidynamic/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>25.</b>
                        
                         UIDynamic
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="26" data-path="coreanimation/README.html">
            
                
                    <a href="../coreanimation/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>26.</b>
                        
                         coreAnimation
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="27" data-path="cocoapods/README.html">
            
                
                    <a href="../cocoapods/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>27.</b>
                        
                         Cocoapods
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="28" data-path="thread/README.html">
            
                
                    <a href="../thread/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>28.</b>
                        
                         Thread
                    </a>
                
            
            
        </li>
    
        
        <li class="chapter " data-level="29" data-path="network/README.html">
            
                
                    <a href="../network/README.html">
                        <i class="fa fa-check"></i>
                        
                            <b>29.</b>
                        
                         network
                    </a>
                
            
            
        </li>
    


        
        <li class="divider"></li>
        <li>
            <a href="http://www.gitbook.io/" target="blank" class="gitbook-link">Published using GitBook</a>
        </li>
        
    </ul>
</div>

    <div class="book-body">
        <div class="body-inner">
            <div class="book-header">
    <!-- Actions Left -->
    <a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
    <a href="#" class="btn pull-left toggle-search" aria-label="Toggle search"><i class="fa fa-search"></i></a>
    
    <div id="font-settings-wrapper" class="dropdown pull-left">
        <a href="#" class="btn toggle-dropdown" aria-label="Toggle font settings"><i class="fa fa-font"></i>
        </a>
        <div class="dropdown-menu font-settings">
    <div class="dropdown-caret">
        <span class="caret-outer"></span>
        <span class="caret-inner"></span>
    </div>

    <div class="buttons">
        <button type="button" id="reduce-font-size" class="button size-2">A</button>
        <button type="button" id="enlarge-font-size" class="button size-2">A</button>
    </div>

    <div class="buttons font-family-list">
        <button type="button" data-font="0" class="button">Serif</button>
        <button type="button" data-font="1" class="button">Sans</button>
    </div>

    <div class="buttons color-theme-list">
        <button type="button" id="color-theme-preview-0" class="button size-3" data-theme="0">White</button>
        <button type="button" id="color-theme-preview-1" class="button size-3" data-theme="1">Sepia</button>
        <button type="button" id="color-theme-preview-2" class="button size-3" data-theme="2">Night</button>
    </div>
</div>

    </div>

    <!-- Actions Right -->
    
    <div class="dropdown pull-right">
        <a href="#" class="btn toggle-dropdown" aria-label="Toggle share dropdown"><i class="fa fa-share-alt"></i>
        </a>
        <div class="dropdown-menu font-settings dropdown-left">
            <div class="dropdown-caret">
                <span class="caret-outer"></span>
                <span class="caret-inner"></span>
            </div>
            <div class="buttons">
                <button type="button" data-sharing="twitter" class="button">Twitter</button>
                <button type="button" data-sharing="google-plus" class="button">Google</button>
                <button type="button" data-sharing="facebook" class="button">Facebook</button>
                <button type="button" data-sharing="weibo" class="button">Weibo</button>
                <button type="button" data-sharing="instapaper" class="button">Instapaper</button>
            </div>
        </div>
    </div>
    

    
    <a href="#" target="_blank" class="btn pull-right google-plus-sharing-link sharing-link" data-sharing="google-plus" aria-label="Share on Google Plus"><i class="fa fa-google-plus"></i></a>
    
    
    <a href="#" target="_blank" class="btn pull-right facebook-sharing-link sharing-link" data-sharing="facebook" aria-label="Share on Facebook"><i class="fa fa-facebook"></i></a>
    
    
    <a href="#" target="_blank" class="btn pull-right twitter-sharing-link sharing-link" data-sharing="twitter" aria-label="Share on Twitter"><i class="fa fa-twitter"></i></a>
    
    

    <!-- Title -->
    <h1>
        <i class="fa fa-circle-o-notch fa-spin"></i>
        <a href="../" >Mou</a>
    </h1>
</div>

            <div class="page-wrapper" tabindex="-1">
                <div class="page-inner">
                
                
                    <section class="normal" id="section-gitbook_36">
                    
                        <h1 id="uiview">UIView</h1>
<p>广告条的高度固定50</p>
<h1 id="uiview">UIView常见属性</h1>
<ul>
<li>NSArray *subviews<ul>
<li>所有的子控件</li>
<li>数组元素的顺序决定着子控件的显示层级顺序</li>
</ul>
</li>
</ul>
<h1 id="uiview">UIView的常见方法</h1>
<ul>
<li>addSubview<ul>
<li>添加一个子控件</li>
<li>使用这个方法添加的子控件会被塞到subviews数组的最后面</li>
</ul>
</li>
<li><p>layoutSubviews;
当一个控件的frame发生改变的时候就会自动调用
一般在这里布局内部的子控件(设置子控件的frame)
一定要调用super的layoutSubviews方法</p>
</li>
<li><p>didMoveToSuperview;
当一个控件被添加到父控件中就会调用</p>
</li>
<li><p>willMoveToSuperview:(UIView *)newSuperview;
当一个控件即将被添加到父控件中会调用</p>
</li>
<li><p>可使用下面的方法调整子控件在subview数组中的顺序</p>
<pre><code class="lang-objc"><span class="hljs-comment">//将子控件view插入到subviews数组的index位置</span>
- (<span class="hljs-keyword">void</span>)insertSubview:(<span class="hljs-built_in">UIView</span> *)view atIndex:(<span class="hljs-built_in">NSInteger</span>)index;
<span class="hljs-comment">//将子控件view显示到子控件siblingSubview的下面</span>
- (<span class="hljs-keyword">void</span>)insertSubview:(<span class="hljs-built_in">UIView</span> *)view belowSubview:(<span class="hljs-built_in">UIView</span> *)siblingSubview;
<span class="hljs-comment">//将子控件view显示到子控件siblingSubview的上面</span>
- (<span class="hljs-keyword">void</span>)insertSubview:(<span class="hljs-built_in">UIView</span> *)view aboveSubview:(<span class="hljs-built_in">UIView</span> *)siblingSubview;
<span class="hljs-comment">//将子控件view放到数组的最后面,显示在最上面</span>
- (<span class="hljs-keyword">void</span>)bringSubviewToFront:(<span class="hljs-built_in">UIView</span> *)view;
<span class="hljs-comment">//将子控件view放到数组的最前面,显示在最下面</span>
- (<span class="hljs-keyword">void</span>)sendSubviewToBack:(<span class="hljs-built_in">UIView</span> *)view;
</code></pre>
<h2 id="">自定义按钮步骤</h2>
<ul>
<li>1.创建一个继承自UIButton的子类,比如YSButton</li>
<li>2.重写初始化,设置数据,layoutSubviews方法在初始化方法中设置基本属性</li>
<li>3.在layoutSubviews方法中调整子控件的位置
让按钮内的文字多行显示除设置numberOfLines = 0,还要设置按钮宽度,将宽度设置为小于等于宽度会随着文字多少来定</li>
</ul>
</li>
</ul>
<h1 id="">图片拉伸三种方法</h1>
<ul>
<li><p>1.image = [image resizableImageWithCapInsets:UIEdgeInsetsMake(30, 0, 30, 30) resizingMode:UIImageResizingModeStretch];</p>
</li>
<li><p>2.image = [image stretchableImageWithLeftCapWidth:image.size.width<em>0.5 topCapHeight:image.size.height </em> 0.5];</p>
</li>
<li><p>3.xcode里设置</p>
<ul>
<li>imageNamed加载图片,当对象销毁时,图片对象不会随着一起销毁
相同图片只会加载一份到内存中
经常用在一些图片在多个界面都会使用,并且图片较小,使用频率高(图标/小的背景图)
imagewithContentOfFile加载图片,当对象销毁时,图形对象会随着一起销毁
相同图片会多次加载到内存中
经常用在:只在一个地方使用,并且图片较大,使用频率不高(版本新特性)</li>
</ul>
</li>
<li><p>使用xib封装一个自定义view的步骤</p>
<ul>
<li>新建一个继承UIView的自定义view,假设类名叫做(MJAppView)</li>
<li>新建一个MJAppView.xib文件来描述MJAppView内部的结构</li>
<li>修改UIView的类型为MJAppView真是类型</li>
<li>将内部的子控件跟MJAppView进行属性连线</li>
<li>MJAppView提供一个模型属性</li>
<li>重写模型属性的set方法,因为在set方法中可以拿到外界传递的模型数据</li>
<li>把模型数据拆开,分别设置数据到对应的子控件中</li>
<li>补充:提供一个创建MJAppView的类方法,将读取xib文件的代码屏蔽起来</li>
</ul>
</li>
<li><p>UIButton与UIImageView的区别</p>
<ul>
<li>显示图片
UIImageView只能显示一种图片
UIButton能显示2种图片背景图(填充整个UIButton)前置(覆盖在背景上的图片)</li>
<li>显示文字
UIImageView不能显示文字
UIButton可以显示文字</li>
<li>点击事件
UIImageView默认不能响应点击事件
UIButton能响应点击事件</li>
<li>使用场合
UIImageView:只显示图片,一般不监听点击
UIButton:既显示图片,又监听点击,点击了图片后做一些其他事情</li>
<li>继承结构
UIButton之所以能添加监听事件,是因为它继承自UIControl
UIImageView之所以不能添加监听事件,是因为它直接继承自UIView</li>
</ul>
</li>
<li><p>IBAction、IBOutlet的作用
从返回值角度上相当于void,但比void多了一层功能保证方法可以连线</p>
</li>
</ul>
<p>frame:改位置\尺寸  bounds:改尺寸(x,y都是0)  center:改位置 transform:位置\尺寸\旋转角度</p>
<p>当UIView需要显示到屏幕上时,会调用drawRect:方法进行绘图,并且会将所有内容绘制在自己的图层上,绘图完毕后,系统会将图层拷贝到屏幕上,于是就完成了UIView的显示
UIView本身不具备显示的功能,是它内部的层才有显示功能</p>
<p>每一个UIView内部都默认关联着一个CALayer,我们可称这个Layer为Root Layer(根层)
所有的非Root Layer,也就是手动创建的CALayer对象,都存在着隐式动画
什么是隐式动画?
当对非Root Layer的部分属性进行修改时,默认会自动产生一些动画效果
而这些属性称为Animatable Properties(可动画属性)
列举几个常见的Animatable Properties:
bounds:用于设置CALayer的宽度和高度。修改这个属性会产生缩放动画
backgroundColor:用于设置CALayer的背景色。修改这个属性会产生背景色的渐变动画
position:用于设置CALayer的位置。修改这个属性会产生平移动画</p>
<ul>
<li>UISwitch</li>
<li>UISwitch继承自UIControl,因此也能像UIButton一样监听一些事件,比如状态改变事件</li>
<li>UISwitch可以通过拖线监听状态改变</li>
<li>UISwitch可以通过addTarget:...方法监听状态改变</li>
<li>(void)addTarget:(id)target action:(SEL)action forControlEvents:(UIControlEvents)controlEvents;
// 其中controlEvents参数传递的是:UIControlEventValueChanged(值改变事件)</li>
</ul>

                    
                    </section>
                
                
                </div>
            </div>
        </div>

        
        <a href="../base/README.html" class="navigation navigation-prev " aria-label="Previous page: base"><i class="fa fa-angle-left"></i></a>
        
        
        <a href="../jiugongge/README.html" class="navigation navigation-next " aria-label="Next page: jiugongge"><i class="fa fa-angle-right"></i></a>
        
    </div>
</div>

        
<script src="../gitbook/app.js"></script>

    
    <script src="https://cdn.mathjax.org/mathjax/2.4-latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML"></script>
    

    
    <script src="../gitbook/plugins/gitbook-plugin-mathjax/plugin.js"></script>
    

<script>
require(["gitbook"], function(gitbook) {
    var config = {"fontSettings":{"theme":null,"family":"sans","size":2}};
    gitbook.start(config);
});
</script>

        
    </body>
    
</html>