(一)UI设计的一些常识
@interface ViewController ()
@end
注意小括号内不能放任何内容,在其内部写声明,可以封装起来内容不要给外界使用。
可以保证封装性。
@interface ViewController ()
- (IBAction)compute;
@property (nonatomic,weak) IBOutlet UITextField *num1;
@property (nonatomic,weak) IBOutlet UITextField *num2;
@property (nonatomic,weak) IBOutlet UILabel *result;
@end
三.常见的控件属性
CGRect tempFrame = self.head.frame;
tempFrame.;
self.head.frame = tempFrame;
通过frame既可以改位置,又可以改大小。
3.查错:
先在相应的方法里加断点,看有没有进入。
其次可以用NSLog。
打印结构体:NSStringFromCGRect();
发现不能改变图片大小:AutoLayout影响的。
代码的优化:例如上下左右四个按钮用一个方法实现。
多个按钮可以拖到同一个IBAction上面。
!当按钮对应的方法有参数时,会把被点击的按钮当做参数传入,例如是按钮,要传入UIButton *
注意修改IBAction后要重新连线。
标识不同的sender,绑定不同的tag。
输入一个数值Tag。
修改控件位置:修改frame与center。
3.设定center
center是CGPoint,可以修改位置。
4.设定bounds
bounds以自己的左上角为坐标原点,但是可以改尺寸。
bounds修改尺寸中心不动,但是frame改尺寸左上角不动。
总结:
frame:修改位置和尺寸(左上角不动)
center:修改位置
bounds:修改尺寸(中心不动)
5.通过代码创建按钮
viewDidLoad方法,在控制器和View被创建完毕后会调用。
创建->加入->改参数
UIButton *btn = [[UIButton alloc] init];
[self.view addSubview:btn];
btn., , , );
UIImage *imgNormal = [UIImage imageNamed:@"btn_01"];
UIImage *imgHighlighted = [UIImage imageNamed:@"btn_02"];
[btn setBackgroundImage:imgNormal forState:UIControlStateNormal];
[btn setBackgroundImage:imgHighlighted forState:UIControlStateHighlighted];
[btn setTitle:@"点我啊" forState:UIControlStateNormal];
[btn setTitle:@"点我干啥" forState:UIControlStateHighlighted];
[btn setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
[btn setTitleColor:[UIColor blueColor] forState:UIControlStateHighlighted];
创建自定义代码的另一种方法:在storyboard中设置后会转为相应的代码。
使用的是buttonWithType类方法创建。
storyboard能办到的东西,代码都能办到。
修改系统默认的按钮类型:
使用代码设置按钮类型:
UIButton *btnInfo = [UIButton buttonWithType:UIButtonTypeRoundedRect];
系统自带的不必设置尺寸。用center来改位置。
通过代码来监听按钮事件:
Target代表的是当前View,这里的self就是当前View。
注意action要包装在@section内。
[btn addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
- (void)btnClick:(UIButton *)button{
NSLog(@"clich the button %@",button);
}
五.头尾动画
[UIView beginAnimations:nil context:nil];
[UIView setAnimationDuration:0.5];
//默认是0.25秒一帧。
[UIView commitAnimations];
bounds为了保证center不变,有一个挪动。
IOS常见的属性改变(如背景变色)都可以使用系统的动画,复杂动画需要自己实现。
补充一些控件和属性
self.head.transform = CGAffineTransformMakeTranslation(deltaX,
deltaY);
注意的是形变属性只允许有一种状态。这是在原来的基础上的改变,多次实施依然deltaX=-100。
解决方法是将deltaX叠加。
最有解决方案:在一个transform基础上生成新的。
,
-);
旋转:注意是弧度制的旋转。
self.head.transform = CGAffineTransformRotate(self.head.transform, M_PI_4);
缩放:填写的是x方向与y方向的缩放比例。
self.head.transform = CGAffineTransformScale(self.head.transform, 1.2, 1.2);
特殊场合用transform,平时可用center、frame、bounds。
UIImage的使用
self.xxximgView.image = [UIImage imageNamed:@“…”];
禁用控件:
btn.enabled = NO;
Disable默认是变灰,也可以修改图片。
试着去精简自己的代码。
除去对象以外的内容用strong。
数据的处理方式:
先把一个数据组写成字典(NSMutabeDictionary可以用[ ]索引来创建键值对)。
然后把字典放入数组。
使用的时候先取出字典,然后使用。
对于key,为了防止前后不一致,可以用#define写宏
有的公司以k开头有的公司以公司前缀开头。
get方法里面千万不要用self,会产生死循环。
延迟加载(懒加载):保证性能,将属性放到get方法中初始化。
用到的功能在使用时加载,例如有些数据只有查看时才将相应的数据初始化。
可以通过重写相应的get方法,注意在get方法用 _xxx == nil来判断是否加载过,千万不要用self,会死循环。
(一)UI设计的一些常识的更多相关文章
- 2018年这些UI设计趋势正在流行,跟上必拿高薪!
数字设计领域和时尚圈是一样的,总会有各种各样的趋势让人眼花缭乱.无论是用户界面的视觉元素,还是用户体验的细节,总有许多值得说道的新玩法和新方向.就目前来看,UI设计的大趋势是更加大胆新颖的视觉设计,通 ...
- 不得不存!UI设计新手不可错过的7条实用法则
http://www.gameres.com/316761.html 本文编译自 Medium,作者是一位UX(User Experience, 用户体验)设计师,他通过自己学习UI设计的过程,总结出 ...
- 开发辅助 | 前端开发工程师对 UI设计、交互设计的认知
1.UI 用户界面 UI:User Interfase 用户界面 UID:User Interfase Designer 用户界面设计师,多指移动 app 的界面设计: 2.一个合格的 UI 设计师, ...
- 缩放因子和UI设计
一.PPI 1.像素密度PPI:PPI(Pixel Per Inch by diagonal):表示沿着对角线,每英寸所拥有的像素(Pixel)数目. 根据勾股定理(直角三角形两边为a和b,斜边为c, ...
- Android 腾讯入门教程( 智能手表UI设计 和 MVC模式 )
*****注意到mvc 在android 中是如何进行分层分域执行各自的功能.**** 官方推荐的按钮尺寸是48像素 前端之Android入门(1):环境配置 前端之Android入门(2):程序目录 ...
- eclipse里打开SWT项目找不到source/design的图形UI设计界面
因为前天重新装了个新版的eclipse, 结果今天打开一个SWT的项目,突然找不到source/design的图形UI设计的两个切换按钮 我把SWT组件重新装了还是找不到.结果后来发现是因为重装ecl ...
- 分享20个最新的免费 UI 设计素材给设计师
用户界面设计涉及到很多的创意,灵感以及需要与客户进行有效沟通的技能.良好的用户界面是一致的,可以使网站更容易理解和使用.UI设计的重点在于用户体验和互动,同时易于使用对于一个成功的移动应用程序来说非常 ...
- UI设计中的48dp定律【转】
有朋友建议我偶尔写写技术类的文章,所以我打算开始穿插性的写一些偏技术方面的科普文章,尽量往小白能看懂的方向写,今天我来讲讲UI设计中的48dp定律. 那么先说说什么是dp ?其实对于一个非技术人员要把 ...
- 2017年8个UI设计流行趋势
设计趋势变化的理由需要考虑各种各样的因素.让我们来一起看看2017年的设计流行趋势吧. 应用界面的设计趋势是不断变化的.随着时间的推移他也在不断的成长,进化.虽然有些趋势还有待检验,但我们还是需要不断 ...
随机推荐
- 存出和载入Docker镜像
存出镜像 如果要导出镜像到本地文件,可以使用 docker save 命令. $ sudo docker images REPOSITORY TAG IMAGE ID CREATED VIRTUAL ...
- 使用Spring Boot开发Web项目(二)之添加HTTPS支持
上篇博客使用Spring Boot开发Web项目我们简单介绍了使用如何使用Spring Boot创建一个使用了Thymeleaf模板引擎的Web项目,当然这还远远不够.今天我们再来看看如何给我们的We ...
- Gradle 1.12用户指南翻译——第四十五章. 应用程序插件
本文由CSDN博客貌似掉线翻译,其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Githu ...
- linux中probe函数中传递的参数来源(上)
点击打开链接 上一篇中,我们追踪了probe函数在何时调用,知道了满足什么条件会调用probe函数,但probe函数中传递的参数我们并不知道在何时定义,到底是谁定义的,反正不是我们在驱动中定义的(当然 ...
- Dynamics CRM 站点地图中URL的&号编码问题
现在大多数人对站点地图的操作都通过工具来执行,但如果你使用原始的编辑XML方式,并且你的SubArea中对应的不是某个Entity而是一串URL时,要注意了你的URL中如果带有与符号即&,那就 ...
- Swift中类似C++和ruby中的final机制
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 我们知道在C++和ruby语言的错误处理中有一种final机制 ...
- Ubuntu和Windows设备共享
http://blog.csdn.net/pipisorry/article/details/51725942 蓝牙设备如键盘.鼠标都可以. 装的双系统win7和Ubuntu,如果只使用一个系统,蓝牙 ...
- Unity UGUI图文混排源码(三) -- 动态表情
这里是根据图文混排源码(二)进一步修改的,其他链接也不贴了,就贴一个链接就好了,第一次看这文章的同学可以先去看看其他几篇文章 Unity UGUI图文混排源码(二):http://blog.csdn. ...
- 【编程练习】poj1068
Parencodings Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 24202 Accepted: 14201 De ...
- iOS下WebRTC音视频通话(三)-音视频通话
前两篇文章记录了音视频通话的一些概念和一些流程,以及一个局域网内音视频通话的示例. 今天以一个伪真实网络间的音视频通话示例,来分析WebRTC音视频通话的过程. 上一篇因为是在相同路由内,所以不需要穿 ...