UITextView
に似たUITextField
にプレースホルダーを挿入する方法はありますか?はいの場合、この機能を実装するためのリンクまたはアイデアを送ってください。
UITextViewでプレースホルダーを作成することはできませんが、これによりプレースホルダーのような効果を生成できます。
- (void)viewDidLoad {
commentTxtView.text = @"Comment";
commentTxtView.textColor = [UIColor lightGrayColor];
commentTxtView.delegate = self;
}
- (BOOL) textViewShouldBeginEditing:(UITextView *)textView {
commentTxtView.text = @"";
commentTxtView.textColor = [UIColor blackColor];
return YES;
}
-(void) textViewDidChange:(UITextView *)textView {
if(commentTxtView.text.length == 0) {
commentTxtView.textColor = [UIColor lightGrayColor];
commentTxtView.text = @"Comment";
[commentTxtView resignFirstResponder];
}
}
-(void) textViewShouldEndEditing:(UITextView *)textView {
if(commentTxtView.text.length == 0) {
commentTxtView.textColor = [UIColor lightGrayColor];
commentTxtView.text = @"Comment";
[commentTxtView resignFirstResponder];
}
}
または、同様にtextviewにラベルを追加できます
lbl = [[UILabel alloc] initWithFrame:CGRectMake(10.0, 0.0,textView.frame.size.width - 10.0, 34.0)];
[lbl setText:kDescriptionPlaceholder];
[lbl setBackgroundColor:[UIColor clearColor]];
[lbl setTextColor:[UIColor lightGrayColor]];
textView.delegate = self;
[textView addSubview:lbl];
および設定
- (void)textViewDidEndEditing:(UITextView *) textView {
if (![textView hasText]) {
lbl.hidden = NO;
}
}
- (void) textViewDidChange:(UITextView *)textView {
if(![textView hasText]) {
lbl.hidden = NO;
}
else {
lbl.hidden = YES;
}
}
別の簡単な解決策は、UILabel
をUITextView
サブビューに追加するだけです。
- (void)viewDidLoad
{
[super viewDidLoad];
// you might have to play around a little with numbers in CGRectMake method
// they work fine with my settings
placeholderLabel = [[UILabel alloc] initWithFrame:CGRectMake(10.0, 0.0, textView.frame.size.width - 20.0, 34.0)];
[placeholderLabel setText:kDescriptionPlaceholder];
// placeholderLabel is instance variable retained by view controller
[placeholderLabel setBackgroundColor:[UIColor clearColor]];
[placeholderLabel setFont:[challengeDescription font]];
[placeholderLabel setTextColor:[UIColor lightGrayColor]];
// textView is UITextView object you want add placeholder text to
[textView addSubview:placeholderLabel];
}
- (void) textViewDidChange:(UITextView *)theTextView
{
if(![textView hasText]) {
[textView addSubview:placeholderLabel];
} else if ([[textView subviews] containsObject:placeholderLabel]) {
[placeholderLabel removeFromSuperview];
}
}
- (void)textViewDidEndEditing:(UITextView *)theTextView
{
if (![textView hasText]) {
[textView addSubview:placeholderLabel];
}
}
必要に応じて、UILabel
をフェードイン/フェードアウトする小さなアニメーションを追加することもできます。
- (void) textViewDidChange:(UITextView *)theTextView
{
if(![textView hasText]) {
[textView addSubview:placeholderLabel];
[UIView animateWithDuration:0.15 animations:^{
placeholderLabel.alpha = 1.0;
}];
} else if ([[textView subviews] containsObject:placeholderLabel]) {
[UIView animateWithDuration:0.15 animations:^{
placeholderLabel.alpha = 0.0;
} completion:^(BOOL finished) {
[placeholderLabel removeFromSuperview];
}];
}
}
- (void)textViewDidEndEditing:(UITextView *)theTextView
{
if (![textView hasText]) {
[textView addSubview:placeholderLabel];
[UIView animateWithDuration:0.15 animations:^{
placeholderLabel.alpha = 1.0;
}];
}
別の簡単な解決策は、placeholderLabelの非表示プロパティにYES/NOを設定することです
- (void)textViewDidEndEditing:(UITextView *)theTextView
{
if (![textView hasText]) {
placeholderLabel.hidden = NO;
}
}
- (void) textViewDidChange:(UITextView *)textView
{
if(![textView hasText]) {
placeholderLabel.hidden = NO;
}
else{
placeholderLabel.hidden = YES;
}
}
-(BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text
{
// NSLog(@"REPlace %@ %d",text,range.location);
if(range.location==0 && ![text isEqualToString:@""])
{
placeholderlbl.hidden = YES;
}
else if(range.location==0)
{
placeholderlbl.hidden = NO;
}
return YES;
}
プレースホルダーを作成するために以下の機能を使用できます。thiを使用して、プレースホルダーを設定できます。
[self addTextViewPlaceholder:self.txtvComment withPlaceholder:@"COMMENT"];
-(void) addTextViewPlaceholder:(UITextView*) tView withPlaceholder:(NSString*) placeholder
{
UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(9,8,tView.bounds.size.width - 16,0)];
label.lineBreakMode = UILineBreakModeWordWrap;
label.numberOfLines = 0;
label.font = [UIFont systemFontOfSize:13.0];
label.backgroundColor = [UIColor clearColor];
label.textColor = [UIColor colorWithRed:0.7 green:0.7 blue:0.7 alpha:1.0];
label.text = placeholder;
label.alpha = 1;
label.tag = 999;
[tView addSubview:label];
[label sizeToFit];
if(![tView.text isEqualToString:@""])
[label setAlpha:0];
[label release];
}
これを使用してプレースホルダーテキストを管理できます。
- (void)textViewDidChange:(UITextView *)textView
{
[self textChange:textView];
}
- (void)textChange:(UITextView *)textView
{
if([textView.text length]>0)
[[textView viewWithTag:999] setAlpha:0];
else
[[textView viewWithTag:999] setAlpha:1];
}
別の解決策は、プレースホルダーUITextViewを実際のUITextViewの上に配置することです。同じフレームを付けます。セットする placeholderTextView.enabled = NO
プレースホルダーTextView。
次に、通常のtextViewにのみデリゲートを設定し、このUITextViewDelegateメソッドを定義します。
- (void)textViewDidChange:(UITextView *)textView
{
NSLog(@"textViewDidChange");
if(self.textView.text.length == 0)
{
self.placeholderTextView.hidden = NO;
}
else
{
self.placeholderTextView.hidden = YES;
}
}