5.7 针对UIView在frame/约束/旋转/缩放/圆角/各种手势的扩展 [iOS开发中的神兵利器]

1. 本节课将为您演示,针对视图类型的一些实用的扩展方法。首先在左侧的项目导航区,打开视图控制器的代码文件。

2. 接着开始编写代码,依次使用视图类型的各个扩展方法。

3. 首先在当前的类文件中,引入已经安装的第三方类库。

4. 添加一个方法,用来演示对视图类的初始化方法的扩展。

5. 通过设置视图对象的水平坐标、垂直坐标、宽度和高度信息,快速创建一个视图对象。

6. 设置视图对象的背景颜色为橙色。

7. 将视图对象添加到根视图,并在控制台输出视图的显示区域信息。

8. 通过设置视图对象的父视图,快速创建一个和父视图相同显示区域的子视图。

9. 设置视图的背景颜色为紫色,然后将视图添加到父视图中。

10. 使用相同的方式,创建第三个视图对象,另外设置父视图的内边距为20。

11. 设置视图的背景颜色为洋红色,然后将视图添加到指定的父视图中。

12. 在控制台输出子视图的显示区域。

13. 然后在视图加载完成的方法中,调用我们刚刚创建的自定义方法。接着点击左上角的[编译并运行]按钮,启动模拟器预览项目。

14. 当前页面上显示了一个紫色背景的视图,其内边距为20,在紫色视图中,包含一个洋红视图。橙色视图的显示区域和紫色视图相同,所以被紫色视图所遮挡。

15. 接着点击右侧的垂直滚动条,跳转到编辑区的底部位置。

16. 添加另一个方法,该方法用来演示,如何快速获取视图的各个属性信息。

17. 首先初始化一个指定坐标和尺寸的视图对象。

18. 接着在控制台,依次输出视图对象的水平坐标和垂直坐标。

19. 然后依次输出视图对象的宽度和高度信息。

20. 依次输出视图对象的顶部位置和底部位置。

21. 输出视图对象的左侧位置和右侧位置。

22. 依次输出视图对象中心点的水平坐标和垂直坐标。

23. 输出视图对象的尺寸信息。

24. 设置视图的背景颜色为橙色,并将视图对象添加根视图中。

25. 如果需要调整视图的坐标和尺寸,我们只需重新设置视图的四个属性即可。

26. 此时视图的坐标和尺寸都被刷新,在控制台输出视图新的水平坐标的值。接着点击右侧的垂直滚动条,跳转到编辑区的顶部位置。

27. 修改此处方法的名称。

28. 接着点击左上角的[编译并运行]按钮,启动模拟器预览项目。

29. 模拟器启动之后,显示了一个橙色背景的视图对象。观察在底部的控制台,所输出的日志信息。然后点击此处的[停止]按钮,关闭模拟器。

30. 点击右侧的垂直滚动条,跳转到编辑区的底部位置。

31. 接着添加另一个方法。

32. 我们将在这个方法中,演示如何根据其它视图,确定另一个视图的位置和尺寸。

33. 首先初始化一个指定坐标和尺寸的视图对象。

34. 设置视图的背景颜色为灰色。

35. 接着初始化另一个视图对象,并设置该视图在水平方向上,位于上个视图右侧20点的位置。在垂直方向上,位于上个视图下方20点的位置。

36. 设置第二个视图的背景颜色为橙色。

37. 接着将两个视图,全部添加到根视图。然后点击右侧的垂直滚动条,跳转到编辑区的顶部位置。

38. 修改此处的方法名称。

39. 接着点击左上角的[编译并运行]按钮,启动模拟器预览项目。

40. 模拟器启动后,显示了两个视图对象,其中橙色视图在灰色视图的右下方,与灰色视图在水平和垂直方向,各偏移20点的距离。

41. 然后点击右侧的垂直滚动条,跳转到编辑区的底部位置。

42. 添加一个方法,用来演示视图之间的对齐。

43. 首先初始化一个指定坐标和尺寸的视图对象,并设置视图对象的背景颜色为紫色。

44. 初始化第二个指定坐标和尺寸的视图对象,并设置视图对象的背景颜色为橙色。

45. 接着将两个视图,全部添加到根视图。

46. 然后将第一个视图,在水平位置上和根视图保持居中。将第二个视图也在两个方向上和根视图保持居中。接着点击垂直滚动条,跳转到编辑区的顶部位置。

47. 修改此处的方法名称。

48. 接着点击左上角的[编译并运行]按钮,启动模拟器预览项目。

49. 模拟器启动后,显示了两个视图对象。紫色视图和根视图在水平方向上居中对齐。而橙色视图则在水平和垂直两个方向上,和根视图保持居中显示。

50. 然后点击右侧的垂直滚动条,跳转到编辑区的底部位置。

51. 添加一个方法,用来演示视图的旋转操作。

52. 首先初始化一个指定坐标和尺寸的视图对象。

53. 设置视图对象的背景颜色为橙色。

54. 设置视图对象沿着水平轴向,旋转四十五度。

55. 将视图对象添加到根视图。接着点击右侧的垂直滚动条,跳转到编辑区的顶部位置。

56. 修改此处的方法名称。

57. 接着点击左上角的[编译并运行]按钮,启动模拟器预览项目。

58. 模拟器启动后,显示了一个在水平方向上旋转四十五度的视图对象。点击此处的[停止]按钮,关闭模拟器。

59. 然后点击右侧的垂直滚动条,跳转到编辑区的底部位置。

60. 接着修改代码,将视图在屏幕的Z轴方向上旋转四十五度。

61. 然后点击右侧的垂直滚动条,跳转到编辑区的顶部位置。

62. 模拟器启动后,显示了一个在Z轴方向上旋转四十五度的视图对象。点击此处的[停止]按钮,关闭模拟器。

63. 接着添加另一个方法。

64. 该方法将用来演示视图的缩放操作。

65. 首先初始化一个指定坐标和尺寸的视图对象,该视图对象的宽度和高度都是100。

66. 设置视图对象的背景颜色为橙色。

67. 设置视图对象在水平方向上放大两倍,在垂直方向上放大四倍。

68. 将缩放后的视图对象,添加到根视图。接着点击右侧的垂直滚动条,跳转到编辑区的顶部位置。

69. 修改此处的方法名称。

70. 然后点击左上角的[编译并运行]按钮,启动模拟器预览项目。

71. 模拟器启动后,显示了一个在水平方向上放大两倍,在垂直方向上放大四倍的视图对象。点击此处的[停止]按钮,关闭模拟器。

72. 然后点击右侧的垂直滚动条,跳转到编辑区的底部位置。

73. 接着添加另一个方法。

74. 该方法将用来演示视图的圆角和边框操作。

75. 首先初始化一个指定坐标和尺寸的视图对象。

76. 接着设置视图的圆角半径为40。

77. 设置视图对象的背景颜色为橙色。

78. 然后设置视图对象的边框宽度为6,颜色为黑色,并将视图对象添加到根视图。接着点击右侧的垂直滚动条,跳转到编辑区的顶部位置。

79. 修改此处的方法名称。

80. 然后点击左上角的[编译并运行]按钮,启动模拟器预览项目。

81. 模拟器启动后,显示了圆角半径为40,边框宽度为6的视图对象。点击此处的[停止]按钮,关闭模拟器。

82. 然后点击右侧的垂直滚动条,跳转到编辑区的底部位置。

83. 接着修改此处的代码,仅给视图添加底部的边框。

84. 点击左上角的[编译并运行]按钮,再次启动模拟器预览项目。

85. 模拟器启动后,显示了一个底部边框宽度为20,边框颜色为红色的视图对象。点击此处的[停止]按钮,关闭模拟器。

86. 点击右侧的垂直滚动条,跳转到编辑区的底部位置。

87. 接着添加另一个方法。

88. 该方法将用来演示,如何给视图快速添加触摸手势。

89. 首先初始化一个指定坐标和尺寸的视图对象。

90. 设置视图对象的背景颜色为橙色。

91. 给视图对象添加一个触摸手势,并设置在一个代码块中,响应触摸的事件。

92. 当视图对象被点击时,在控制台输出相应的日志信息。

93. 将视图对象添加到根视图。接着点击右侧的垂直滚动条,跳转到编辑区的顶部位置。

94. 修改此处的方法名称。

95. 然后点击左上角的[编译并运行]按钮,启动模拟器预览项目。

96. 模拟器启动后,在此处的橙色视图上点击,并观察控制台的日志输出。

97. 此时在控制台输出了视图点击手势的日志信息。点击此处的[停止]按钮,关闭模拟器。

98. 然后点击右侧的垂直滚动条,跳转到编辑区的底部位置。

99. 接着修改代码,使用代理的方法,处理交互事件。

100. 视图的触摸事件,将由当前的控制器对象来处理。

101. 添加一个方法,响应视图的触摸事件。

102. 接着添加一个方法,演示如何给视图添加手指轻扫的手势。

103. 首先初始化一个指定坐标和尺寸的视图对象。

104. 设置视图对象的背景颜色为橙色。

105. 给视图对象添加一个轻扫手势,并设置在一个代码块中,响应触摸的事件。

106. 当视图对象被点击时,在控制台输出滑动手势的方向,以及手指的数目。

107. 将视图对象添加到根视图。接着点击右侧的垂直滚动条,跳转到编辑区的顶部位置。

108. 修改此处的方法名称。

109. 然后点击左上角的[编译并运行]按钮,启动模拟器预览项目。

110. 模拟器启动后,在此处的橙色视图上手指轻扫,并观察控制台的日志输出。

111. 此时在控制台,输出了视图上的轻扫手势的日志信息。点击此处的[停止]按钮,关闭模拟器。

112. 然后点击右侧的垂直滚动条,跳转到编辑区的底部位置。

113. 接着添加另一个方法。

114. 该方法将用来演示,如何给视图快速添加拖拽手势。

115. 首先初始化一个指定坐标和尺寸的视图对象,并设置视图对象的背景颜色为橙色。

116. 获得视图中心点的位置。

117. 给视图对象添加一个拖拽手势,并设置在一个代码块中,响应触摸的事件。

118. 当手势事件处于开始状态时,获得视图此时的中心点的位置。

119. 接着获得拖拽手势在视图中的移动距离。

120. 然后通过计算,获得视图在经过拖拽之后的目标位置。

121. 刷新视图中心点的坐标,从而改变视图的位置。

122. 将视图对象添加到根视图。接着点击右侧的垂直滚动条,跳转到编辑区的顶部位置。

123. 修改此处的方法名称。

124. 然后点击左上角的[编译并运行]按钮,启动模拟器预览项目。

125. 模拟器启动后,在上方的圆点处按下手指,并向下方拖动,移动视图的位置。

126. 此时视图被移至屏幕的右下角。点击此处的[停止]按钮,关闭模拟器。

127. 然后点击右侧的垂直滚动条,跳转到编辑区的底部位置。

128. 接着添加另一个方法。

129. 该方法将用来演示,如何给视图快速添加捏合手势。

130. 首先初始化一个指定坐标和尺寸的视图对象,并设置视图对象的背景颜色为橙色。

131. 给视图对象添加一个捏合手势,并设置在一个代码块中,响应触摸的事件。

132. 通过捏合手势的缩放比例,实时调整视图的显示比例。

133. 将视图对象添加到根视图。接着点击右侧的垂直滚动条,跳转到编辑区的顶部位置。

134. 修改此处的方法名称。

135. 然后点击左上角的[编译并运行]按钮,启动模拟器预览项目。

136. 模拟器启动后,在右上方的圆点处按下手指,并向左下方拖动,缩小视图的显示比例,并观察控制台的日志输出。

137. 视图被缩小至一个较小的尺寸,在控制台输出了,视图缩放过程中的比例日志。

138. 然后点击右侧的垂直滚动条,跳转到编辑区的底部位置。

139. 接着添加另一个方法。

140. 该方法将用来演示,如何给视图快速添加长按手势。首先初始化一个指定坐标和尺寸的视图对象,并设置视图对象的背景颜色为橙色。

141. 给视图添加一个长按手势,并设置在一个代码块中,响应触摸的事件。

142. 当视图被长按时,使视图左右晃动三次。

143. 并给视图添加一个阴影。

144. 将视图对象添加到根视图。接着点击右侧的垂直滚动条,跳转到编辑区的顶部位置。

145. 修改此处的方法名称。

146. 然后点击左上角的[编译并运行]按钮,启动模拟器预览项目。

147. 模拟器启动后,在视图的上方长按手指,并观察视图的变化。

148. 此时视图增加了投影的效果,点击此处的[停止]按钮,关闭模拟器。

149. 然后点击右侧的垂直滚动条,跳转到编辑区的底部位置。

150. 接着添加另一个方法。

151. 该方法将用来演示,对按钮类型的扩展。

152. 使用扩展后的初始化语句,初始化一个按钮控件,并设置它的坐标、尺寸、目标和动作等属性。

153. 将按钮控件移动至根视图的中心位置。

154. 接着依次设置按钮控件,在正常状态和高亮状态时的背景颜色。

155. 设置按钮在正常状态下的标题文字。

156. 设置按钮的背景颜色为橙色,并将按钮添加到根视图。

157. 添加一个方法,用来响应按钮的点击事件。接着点击右侧的垂直滚动条,跳转到编辑区的顶部位置。

158. 修改此处的方法名称。

159. 然后点击左上角的[编译并运行]按钮,启动模拟器预览项目。

160. 模拟器启动后,点击此处的按钮控件,并观察控制台的日志输出。

161. 此时在底部的控制台,输出了按钮事件的日志信息。本节课为您讲解了大量的扩展实例,最好多复习几遍以上的知识。最后关闭模拟器,并结束本节课程。

本文整理自:《app开发中的神兵利器》,真正的[手把手]教学模式,用最快的速度上手iOS开发,苹果商店App Store免费下载:https://itunes.apple.com/cn/app/id1209739676,或扫描本页底部的二维码。课程配套素材下载地址:资料下载

apps8 2.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,132评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,802评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,566评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,858评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,867评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,695评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,064评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,705评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,915评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,677评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,796评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,432评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,041评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,992评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,223评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,185评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,535评论 2 343

推荐阅读更多精彩内容