穿透图片响应下层image事件

在做绚丽的界面的时候经常会用到不规则的图片,而我们美工给的图片一般都是方形的图片,在不规则的图形背后还有透明的部分。然而如果我们都使用整体的图片的话,很多图片就会出现交叉的部分,再比如我们如果给每一个图片添加一个点击事件的话上面的图片就会截取下面图片的事件。这样就给我们带来很大的困扰。

如果我们要解决这个问题就需要我们清晰的了解事件的发生和传递是怎么一个流程。为什么我们点击一个按钮,只有这个按钮会触发效果,而界面其他地方没有触发效果,为什么我们触摸屏幕会引发这一系列的事件等等。这些就是今天这个问题的原因。

在这里就先解决一下如何才能穿透上面的图片,响应下面图片的事件。

先看一下效果图穿透效果
1.红色部分实际是一张图片,只是没有放一张图片来区分,只是简单的给一个色值表示跟上面的图片是两个部分。
2.如果我要点击炸弹的圆弧部分能不能响应到红色图片的事件呢?这就是下面代码要解决的问题。
3.我们将上面的图片继承自定义的UIImageView类TouchImageViewUnder,而在自定义的类里面我们需要这个方法:

- (BOOL)pointInside:(CGPoint)point withEvent:(UIEvent *)event {

    unsigned char pixel[1] = {0};
    CGContextRef context = CGBitmapContextCreate(pixel,1, 1, 8, 1, NULL,kCGImageAlphaOnly);
    UIGraphicsPushContext(context);
    CGSize imageViewSize = CGSizeMake(self.frame.size.width, self.frame.size.height);
    CGSize imageSize = CGSizeMake(self.image.size.width, self.image.size.height);
    CGPoint imagePoint =CGPointMake(-point.x * imageSize.width/imageViewSize.width, -point.y * imageSize.height/imageViewSize.height);
    [self.image drawAtPoint:imagePoint];
    UIGraphicsPopContext();
    CGContextRelease(context);
    CGFloat alpha = pixel[0]/255.0f;
    BOOL transparent = alpha < 0.01f;

    return !transparent;
}

4.在使用这个效果的图片布局代码如下

//初始化点击背景图片方法
    UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tapImageView:)];
    UITapGestureRecognizer *tapsmall = [[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tapSmallImageView:)];
    //声明背景图片
    self.bgImageView = [[UIImageView alloc]initWithFrame:CGRectMake(50, 100, 220, 200)];
    _bgImageView.backgroundColor = [UIColor redColor];
    _bgImageView.userInteractionEnabled = YES;
    [_bgImageView addGestureRecognizer:tap];
    [self.view addSubview:_bgImageView];
    self.smallImageView = [[TouchImageViewUnder alloc]initWithFrame:CGRectMake(130, 150, 74, 111.6)];
    [_smallImageView setImage:[UIImage imageNamed:@"zadan.png"]];
    _smallImageView.userInteractionEnabled = YES;
    [_smallImageView addGestureRecognizer:tapsmall];
    [self.view  addSubview:_smallImageView];

5.触发事件代码

-(void)tapImageView:(UITapGestureRecognizer*)gesture
{
    NSLog(@"触摸了底部图片");
}
-(void)tapSmallImageView:(UITapGestureRecognizer*)gesture
{
    NSLog(@"触摸了小图片");
}

6.当我们点击小图片的黑色区域时打印结果是:触摸了小图片,而我们触摸红色区域的时候打印结果是:触摸了底部图片。

我们最核心的代码实际是在自定义的UIImageView中,它的作用就是讲透明的图片部分响应至下一层view的事件,而下一层的意义不在于[self.view addsubview ziview];而是我们直观上看到的谁在上面,谁在下面就可以了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值