前言
最近学了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有所帮助,如果有疑问大家可以留言交流。