(五)超级猜图Demo引出的细节
/**
* 控制状态栏的样式
*
* @return UIStatusBarStyle
*/
- (UIStatusBarStyle)preferredStatusBarStyle{
return UIStatusBarStyleLightContent;
}
3.修改应用名称:
点击工程,改完后回车,点击rename,再选择manage scheme,修改,注意都是单击。
4.代码块的制作:
<#属性名#>可以生成可以填写的提示空位。
5.点击图片方法、背景变灰的实现:
因为点击阴影也会返回,因此阴影也是一张图片。
首先在UIView上盖一张阴影UIButton。然后把头像调整到阴影上面,然后放大挪动到中间(动画)。
将某个控件置于顶层:
[self.view bringSubviewToFront:self.iconBtn];
小Tip:发现图片大小无法调整,可能是由于autolayout。
/2用*0.5表示可以提高效率。
//1.添加阴影
UIButton *cover = [[UIButton alloc] init];
cover., , , );
cover.backgroundColor = [UIColor blackColor];
cover.alpha = 0.7;
[cover addTarget:self action:@selector(smallImg) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:cover];
//2.更改阴影和头像位置
[self.view bringSubviewToFront:self.iconBtn];
//3.更改头像尺寸
[UIView beginAnimations:nil context:nil];
[UIView setAnimationDuration:0.5];
CGFloat iconW = self.view.frame.size.width;
CGFloat iconH = iconW;
;
CGFloat iconY = (self.view.frame.size.height -
iconH) * 0.5;
self.iconBtn.frame = CGRectMake(iconX, iconY, iconW, iconH);
[UIView commitAnimations];
6.删除已有的视图,实现图像复位,阴影消失。
调用控件的removeFromSuperview方法来删除。
做法1,给方法一个参数,使用addTarget参数设置监听:
[cover addTarget:self action:@selector(smallImg:) forControlEvents:UIControlEventTouchUpInside];
- (void)smallImg : (UIButton *)btn{
[btn removeFromSuperview];
}
做法2,让cover是一个成员变量。
cover是一个成员变量的好处:让头像这个按钮有两种动作,放大和缩小
只要在按钮函数里面判断cover是否是nil,来调用放大和缩小。
监听动画结束:
[UIView setAnimationDelegate:self];
[UIView setAnimationDidStopSelector:@selector(deleteCover)];
使用block动画:
[UIView animateWithDuration:<#(NSTimeInterval)#> animations:<#^(void)animations#> completion:<#^(BOOL finished)completion#>]
第一个为动画持续时间,第一个block为动画代码,第二个block为动画结束的代码(block上敲回车可生成)。
推荐使用block动画。
7.取消按钮点击变灰(头像放大缩小不需要)
在属性面板取消Highlighted Adjust Image。
8.猜图的小图标排列技巧:
先加入一个长条的UI父控件,这样只需要调整父控件就可以调整所有子控件。
添加一个view,然后在上面操作。
注意在添加答案按钮前先清空所有按钮。
for (UIView *subview in self.answerView.subviews){
[subview removeFromSuperview];
}
Tip:一个方法中不应该有太多的代码。
应该进行切割,把不同的功能放到不同的方法中去。
例如下面的代码,分割在三个方法内。
/**
* 添加正确答案
*
* @param question 问题模型Question
*/
- (void)addAnswer:(Question *)question{
for (UIView *subview in self.answerView.subviews){
[subview removeFromSuperview];
}
int length = question.answer.length;
; i < length; i++){
UIButton *answerBtn = [[UIButton alloc] init];
[answerBtn setBackgroundImage:[UIImage imageNamed:@"btn_answer"] forState:UIControlStateNormal];
[answerBtn setBackgroundImage:[UIImage imageNamed:@"btn_answer_highlighted"] forState:UIControlStateHighlighted];
CGFloat marginMedium = 10.0;
;
;
CGFloat viewW = self.view.frame.size.width;
)*marginMedium) * 0.5;
CGFloat answerX = leftMargin + i * (answerW + marginMedium);
answerBtn., answerW, answerH);
[self.answerView addSubview:answerBtn];
}
}
/**
* 添加待选项
*
* @param question 问题模型Question
*/
- (void)addOption:(Question *)question{
int count = question.options.count;
; i < count; i++){
UIButton *optionBtn = [[UIButton alloc] init];
[optionBtn setBackgroundImage:[UIImage imageNamed:@"btn_option"] forState:UIControlStateNormal];
[optionBtn setBackgroundImage:[UIImage imageNamed:@"btn_option_highlighted"] forState:UIControlStateHighlighted];
;
;
;
;
;
;
CGFloat viewW = self.view.frame.size.width;
;
) * marginX) * 0.5;
CGFloat optionX = leftMargin + col * (optionW + marginX);
CGFloat optionY = row * (optionH + marginY);
optionBtn.frame = CGRectMake(optionX, optionY, optionW, optionH);
[optionBtn setTitle:question.options[i] forState:UIControlStateNormal];
[optionBtn setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
[self.optionView addSubview:optionBtn];
}
}
/**
* 设置控件数据
*
* @param question 问题模型Question
* @param btn 触发事件的Button(下一题按钮)
*/
- (void)setData:(Question *)question andBtn:(UIButton *)btn{
btn. ? YES : NO;
self.titlelabel.text = question.title;
,self.questions.count];
[self.iconBtn setImage:[UIImage imageNamed:question.icon] forState:UIControlStateNormal];
}
- (IBAction)nextQuestion:(id)sender {
self.index++;
UIButton *btn = (UIButton *)sender;
Question *question = self.questions[self.index];
[self setData:question andBtn:btn];
[self addAnswer:question];
[self addOption:question];
}
NSString *answerTitle = [answerBtn titleForState:UIControlStateNormal];
另一种方法:
NSString *answerTitle = answerBtn.currentTitle;
2.延时执行:
[self performSelector:@selector(nextQuestion:) withObject:nil afterDelay:0.5];
获取已有软件的素材:
[self.answerView.subviews makeObjectsPerformSelector:@selector(removeFromSuperview)];
一个技巧:
为了点击提示的时候可以将已经输入的退回,要实现这一步一般的思路是执行遍历,另一个思路是调用答案框按钮的点击方法,将所有的按钮都点击一次
这就相当于是退回了所有的输入选项。同样,提示的第一个字,应该相当于点击了选项中的那个字。
要多进行类似的“这个操作比较麻烦,但是相当于…”这样的思路转化。
字符串的截取:
substringToIndex:index方法表示截取到index之前,例如index=3,表示截取0-2。
字符串的判等:
isEqualToString方法。
(五)超级猜图Demo引出的细节的更多相关文章
- (八)喜马拉雅Demo引出的细节(代理模式和图片缩放)
喜玛拉雅是一款电台APP,界面非常美观,通过模仿这一APP学习到很多细节. 1.图片导入后有些框内不全如何补全: 寻常的办法是再准备一张图片拖入,比较好的办法是右击已经导入的图片选择Show in F ...
- [Python]网络爬虫(五):urllib2的使用细节与抓站技巧
转自:http://blog.csdn.net/pleasecallmewhy/article/details/8925978 前面说到了urllib2的简单入门,下面整理了一部分urllib2的使用 ...
- [Python]网络爬虫(五):urllib2的使用细节与抓站技巧(转)
1.Proxy 的设置 urllib2 默认会使用环境变量 http_proxy 来设置 HTTP Proxy. 如果想在程序中明确控制 Proxy 而不受环境变量的影响,可以使用代理. 新建test ...
- nRF5 SDK for Mesh(五) Light switch demo 点灯例子
Light switch demo 灯开demo Purpose This demo project consists of four sub examples - The light swit ...
- 自己实现简单的AOP(五)使Demo适应webApi、亦可完成属性自动注入
在前文的Demo中,webApi的Controller是不能自动注入的,原因是 IHttpController 和 IController 是通过两个不同的途径进行激活的. IHttpControll ...
- iOS实现(超级猜图)源码
//首先建立模型文件 QLLQuestion.hheQLLQuestion.m文件 #import <Foundation/Foundation.h> @interface QLLQues ...
- (五)backbone - DEMO - 通信录改造之使用requirejs
DEMO介绍是 DEMO通信录的扩展,使用requirejs模块化整合 大体实现 • model文件 model/contact.js define(function (){ // user cont ...
- (三十八)从私人通讯录引出的细节II -数据逆传 -tableView点击 -自定义分割线
项目中的警告是不会影响app发布的,例如引入第三方类库很容易引入警告. 细节1:跳转的数据传递. prepareForSegue: sender: 方法是在执行segue后,跳转之前调用这个方法,一般 ...
- (三十七)从私人通讯录引出的细节I -Notification -Segue -HUD -延时
细节1:账号和密码都有值的时候才可以点击登录按钮,因此应该监听文本框的文本改变. 因为文本框的文本改变代理不能处理,因此应该使用通知Notification. 文本框文本改变会发出通知:通知的前两个参 ...
随机推荐
- docker环境 快速使用elasticsearch-head插件
docker环境 快速使用elasticsearch-head插件 #elasticsearch配置 #进入elk容器 docker exec -it elk /bin/bash #head插件访问配 ...
- Java内存泄漏分析系列之四:jstack生成的Thread Dump日志线程状态
原文地址:http://www.javatang.com Thread Dump日志的线程信息 以下面的日志为例: "resin-22129" daemon prio=10 tid ...
- 教你如何在Android 6.0上创建系统悬浮窗
郭霖大神的文章:http://mp.weixin.qq.com/s?__biz=MzA5MzI3NjE2MA==&mid=2650235949&idx=1&sn=0f7eded ...
- (译)快速指南:用UIViewPropertyAnimator做动画
翻译自:QUICK GUIDE: ANIMATIONS WITH UIVIEWPROPERTYANIMATOR 译者:Haley_Wong iOS 10 带来了一大票有意思的新特性,像 UIViewP ...
- C算法实现:将字符串中的数字返回为整型数
今天看linux内核驱动的代码,发现一个算法写得挺简单,也有意思. 分享一下我的测试代码: #include <stdio.h> typedef int U32 ; U32 String2 ...
- Android图表库MPAndroidChart(四)——条形图的绘制过程过程,隐隐约约我看到了套路
Android图表库MPAndroidChart(四)--条形图的绘制过程过程,隐隐约约我看到了套路 在学习本课程之前我建议先把我之前的博客看完,这样对整体的流程有一个大致的了解 Android图表库 ...
- Swift中类似C++和ruby中的final机制
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 我们知道在C++和ruby语言的错误处理中有一种final机制 ...
- sublime text3空格和tab的显示
最近在使用sublime text3修改shell文件时,明明看着相同的文件,对比却说不一样.最后发现是空格和tab惹的祸. 1.显示空格和tab: 在Preferences→Key Bindings ...
- API创建员工支付方式
DECLARE ln_method_id PAY_PERSONAL_PAYMENT_METHODS_F.PERSONAL_PAYMENT_METHOD_ID%TYPE; ln_ext_acc_id P ...
- UNIX网络编程——带外数据小结
TCP没有真正的带外数据,不过提供紧急模式和紧急指针.一旦发送端进入紧急模式,紧急指针就出现在发送到对端的分节中的TCP首部中.连接的对端收取该指针是在告知接收进程发送端已经进入紧急模式,而且该指针指 ...