我们经常会看见很多漂亮的UITextField,但是系统的UITextField还是相对比较简单的,往往并不能符合我们的需求。那到底该怎么实现呢,其实也不是很难,只要我们新建一个类继承UITextField,重新drawRect即可。
我们新建一个CustomTextField 类,继承UITextField.
主要代码:
.h文件代码
1
2
3
4
5
|
#import <UIKit/UIKit.h>
@interface mCustomTextField : UITextField
@end
|
.m文件实现代码:
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
//
// mCustomTextField.m
// MapDemo
//
// Created by Carl on 13-7-20.
// Copyright (c) 2013年 contact..com. All rights reserved.
//
#import "mCustomTextField.h"
@implementation mCustomTextField
- (id)initWithFrame:(CGRect)frame
{
self = [super initWithFrame:frame];
if
(self) {
// Initialization code
}
return
self;
}
-(CGRect)textRectForBounds:(CGRect)bounds
{
return
CGRectInset(bounds, 5, 0);
}
-(CGRect)editingRectForBounds:(CGRect)bounds
{
return
CGRectInset(bounds,5,0);
}
-(
void
)drawRect:(CGRect)rect
{
UIImage * backgroundImage = [[UIImage imageNamed:@
"text_field_teal.png"
] resizableImageWithCapInsets:UIEdgeInsetsMake(15.0, 5.0, 15.0, 5.0)];
[backgroundImage drawInRect:[self bounds]];
}
/*
// Only override drawRect: if you perform custom drawing.
// An empty implementation adversely affects performance during animation.
- (void)drawRect:(CGRect)rect
{
// Drawing code
}
*/
@end
|
![](https://i-blog.csdnimg.cn/blog_migrate/1a948fbe50c64023ac3ad5d401afbb45.png)