UIImageView默认的UserInteractionEnabled是NO

本文探讨了在iOS开发中遇到的问题:如何在UIImageView作为背景的情况下,使得按钮或UITextField能够响应事件。通过将按钮或UITextField放置在一个单独的UIView上,然后将这个UIView作为UIImageView的子视图,可以解决事件响应问题。此方法适用于解决类似场景下的界面布局与交互设计问题。
一直习惯用UIImageView作为背景,但直接把按钮或者UITextField放在上面无法相应事件。如下面:

UIImageView * commentBG = [[UIImageViewalloc]initWithFrame:CGRectMake(0,370, 320, 35)];
commentBG.image = [[UIImageimageNamed:@"seachbg.png"]stretchableImageWithLeftCapWidth:2topCapHeight:2];

UITextField * commentField = [[UITextFieldalloc] initWithFrame:CGRectMake(10,10,250,30)];
commentField.borderStyle =UITextBorderStyleRoundedRect;
commentField.placeholder =@"写评论";
commentField.backgroundColor = [UIColorwhiteColor];
commentField.delegate =self;
commentField.returnKeyType =UIReturnKeyGo;
[commentBG addSubview:commentField];
[commentField release];

[self.viewaddSubview:commentBG];
[commentBG release];

这是因为UIImageView默认的UserInteractionEnabled是NO,修改方法可以在添加
commentBG.UserInteractionEnabled=NO;
也可以建一个UIView,把背景放在UIView上,再把按钮或者UITextField放在UIView上面。如下面:
UIView * commentView = [[UIViewalloc] initWithFrame:CGRectMake(0,370, 320, 35)];
UIImageView * commentBG = [[UIImageViewalloc]initWithFrame:CGRectMake(0,370, 320, 35)];
commentBG.image = [[UIImageimageNamed:@"seachbg.png"]stretchableImageWithLeftCapWidth:2topCapHeight:2];
[commentView addSubview:commentBG];
[commentBG release];


UITextField * commentField = [[UITextFieldalloc] initWithFrame:CGRectMake(10,10,250,30)];
commentField.borderStyle =UITextBorderStyleRoundedRect;
commentField.placeholder =@"写评论";
commentField.backgroundColor = [UIColorwhiteColor];
commentField.delegate =self;
commentField.returnKeyType =UIReturnKeyGo;
//commentField.userInteractionEnabled = YES;
[commentView addSubview:commentField];
[commentField release];

[self.viewaddSubview:commentView];
[commentView release];
原文地址:[url]http://blog.youkuaiyun.com/terrylee_cold/article/details/7198229[/url]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值