前言
最近学了uitextfield控件, 感觉在里面设置占位符非常好, 给用户提示信息, 于是就在想占位符的字体和颜色能不能改变呢?下面是小编的一些简单的实现,有需要的朋友们可以参考。
修改uitextfield的占位符文字颜色主要有三个方法:
1、使用attributedplaceholder属性
1
|
@property(nullable, nonatomic,copy) nsattributedstring *attributedplaceholder ns_available_ios(6_0); // default is nil |
2、重写drawplaceholderinrect方法
1
|
- ( void )drawplaceholderinrect:(cgrect)rect; |
3、修改uitextfield内部placeholderlaber的颜色
1
|
[textfield setvalue:[uicolor graycolor] forkeypath@ "placeholderlaber.textcolor" ]; |
以下是详细的实现过程
给定场景,如在注册登录中,要修改手机号和密码textfield的placeholder
的文字颜色。
效果对比
使用前
使用后
使用attributedplaceholder
自定义gylloginregistertextfield
类,继承自uitextfield;实现awakefromnib()
方法,如果使用storyboard
,那么修改对应的uitextfield的customclass
为gylloginregistertextfield
即可
具体代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
#import "gylloginregistertextfield.h" @implementation gylloginregistertextfield - ( void )awakefromnib { self.tintcolor = [uicolor whitecolor]; //设置光标颜色 //修改占位符文字颜色 nsmutabledictionary *attrs = [nsmutabledictionary dictionary]; attrs[nsforegroundcolorattributename] = [uicolor whitecolor]; self.attributedplaceholder = [[nsattributedstring alloc] initwithstring:self.placeholder attributes:attrs]; } @end |
重写drawplaceholderinrect方法
与方法一同样,自定义gylloginregistertextfield
,继承自uitextfield,重写drawplaceholderinrect
方法,后续相同
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
#import "gylloginregistertextfield.h" @implementation gylloginregistertextfield - ( void )awakefromnib { self.tintcolor = [uicolor whitecolor]; //设置光标颜色 } - ( void )drawplaceholderinrect:(cgrect)rect { nsmutabledictionary *attrs = [nsmutabledictionary dictionary]; attrs[nsforegroundcolorattributename] = [uicolor whitecolor]; attrs[nsfontattributename] = self.font; //画出占位符 cgrect placeholderrect; placeholderrect.size.width = rect.size.width; placeholderrect.size.height = rect.size.height; placeholderrect.origin.x = 0; placeholderrect.origin.y = (rect.size.height - self.font.lineheight) * 0.5; [self.placeholder drawinrect:placeholderrect withattributes:attrs]; //或者 /* cgpoint placeholderpoint = cgpointmake(0, (rect.size.height - self.font.lineheight) * 0.5); [self.placeholder drawatpoint:placeholderpoint withattributes:attrs]; */ } @end |
修改uitextfield内部placeholderlaber的颜色
使用kvc机制,找到uitextfield内部的修改站位文字颜色的属性:placeholderlaber.textcolor
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
|
#import "gylloginregistertextfield.h" @implementation gylloginregistertextfield - ( void )awakefromnib { self.tintcolor = [uicolor whitecolor]; //设置光标颜色 //修改占位符文字颜色 [self setvalue:[uicolor graycolor] forkeypath@ "placeholderlaber.textcolor" ]; } @end |
第三种方法比较简单,建议可以将此封装:扩展uitextfield,新建category,添加placeholdercolor
属性,使用kvc重写set
和get
方法。
总结
以上就是这篇文章的全部内容了,希望能对大家开发ios有所帮助,如果有疑问大家可以留言交流。