UIImageView+UILabel+UIButton的小Demo--超级猜图


利用UIImageView+UILabel+UIButton做的一个小程序:

UIImageView+UILabel+UIButton的小Demo--超级猜图_第1张图片
首先要实现各个控件的静态布局,要做好每个设备的适配。
因为我是小白,不太懂其他的适配方法,我就用比例来适配。
比如说:就6s的屏幕   375 x 667 的宽高来说,中间大图的宽高固定是182.5 x 182.5 那么宽对于屏幕的比例就是 182.5/375=0.5  ,高和宽一样。
即宽高  都为:

[UIScreen mainScreen].bounds.size.width * 0.5

用这种比例的方式来布局控件,就可以解决适配的问题

一般来说,先固定一个按钮的比例位置(也可以是绝对位置),然后其他的控件相对于这个控件来布局即可


点击下面被选按钮,会把文字传到答案选项框里面,且被选按钮文字隐藏,如果答案错了,答案选项框字体为红色。

实现的思路:
前提:答案按钮4个button是放在一个view里面的,被选答案按钮button也全是放在另一个view里面
点击被选答案按钮时候,遍历答案的view里面的UIButton,如果UIButton.currentTitle.lenght == 0的话,就把被选答案的当前文字设置为答案按钮的文字。然后被选答案隐藏起来。


如果被选答案全对,那么答案区域的字体就显示橙色字体,过0.5秒后自动到下一题,并且分数增加10分。
实现思路:
遍历答案区域的按钮的文字,然后记录下来,然后跟已经转化成模型的当前答案比较,对的话字体就显示橙色并且加10分。分数机制可以自己设置。

UIImageView+UILabel+UIButton的小Demo--超级猜图_第2张图片
点击图片会放大,并且背景半透明白色。点击背景或者图片,还原图片的位置。
实现思路:
图片后面其实就是加了一个UIButton(遮罩)而已,然后设置这个UIButton的宽为屏幕的宽,高为屏幕的高,背景颜色为white,alpha为0.        
 当UIButton的alpha为0时候,然后把当前ImageView的frame设置为

CGRectMake(0, (ScreenHeight -ScreenWidth)*0.5,ScreenWidth,ScreenWidth);然后这是UIButton的alpha为0.5,然后把ImageView加到self.view的最上层。(

[self.viewbringSubviewToFront:self.bigImage];

ScreenWidth和ScreenHeight是屏幕宽高,我自定义过了。为什么要这样设置frame? 不要问为什么,就问你这样设置出来效果好看不?

当UIButton的alpha为0.5时候,还原当前ImageView原来的frame(可以临时保存他原来的frame)。然后设置UIButton的alpha为0.


除了这种方法之外,也可以用UITapGestureRecognizer来实现。这里就不赘述,可以自己改变来试试。

UIImageView+UILabel+UIButton的小Demo--超级猜图_第3张图片

PS:无论用哪种方法,当ImageView还原到原来位置的时候,他处于视图层的位置和原来不一样了。这个Demo看不出来效果,如果你要做九宫格的图片或者多张图片,也是用这种方法实现放大效果的话,那么会出现缩小的图片也出现在放大图片的后面,而且还能点击。解决办法:可以先遍历self.view的子视图,仔细观察每个视图的frame的位置,你会发现因为他的视图层关系变化而导致的。可以直接把UIButton(遮罩)再加到self.view上面一次,强行改变他的视图层关系,就可以了。


个人觉得以上几点比较重要,其余的话,可以自己简单理解下。


此Demo仅供参考,小白写的不太好,忘见谅。


代码网址:https://github.com/HZhenF/Superguess.git
代码参考:点击打开链接








你可能感兴趣的:(iOS-控件详解)