我希望在点击时让我的 UIImage 短暂地“突出显示”。还不确定颜色,但为了争论起见,让我们说蓝色。因此,您点击图片,它会短暂显示为蓝色,然后它会将您导航到详细信息页面,以便在另一个屏幕上编辑内容。
从一些初步阅读来看,正确的做法似乎是使用 Quartz 框架并执行以下操作:
imageView.layer.backgroundColor = UIColor.blueColor()
imageView.layer.opacity = 0.7
我想你的想法是改变图像后面图层的背景,然后通过设置图像的不透明度,蓝色“渗透”一点点,给你一个略带蓝色的图像?
但是,当我尝试上述操作时,图像本身会出现蓝色边框,并且根据不透明度,蓝色要么是深色要么是浅色。实际图像并没有变得更蓝,但它确实对不透明度使用react(这意味着如果我将其设置为类似 .1 的值,图像会非常褪色并且几乎看不见)。为什么图像 react 正确,但不显示蓝色?
非常感谢!
最佳答案
据我所知,改变不透明度会改变整个 View 的不透明度,这意味着不仅仅是 UIImageView 持有的 UIImage。因此,不是褪色以显示 UIImageView 的背景颜色,而是整个 View 的不透明度只是降低,如您所见。
另一种方法是在 UIImageView 之上添加一个初始透明的 UIView 并改为更改其不透明度:
UIView *blueCover = [[UIView alloc] initWithFrame: myImageView.frame];
blueCover.backgroundColor = [UIColor blueColor];
blueCover.layer.opacity = 0.0f;
[self.view addSubview: blueCover];
[UIView animateWithDuration:0.2f animations^{
blueCover.layer.opacity = 0.5f
}];
关于ios - 在 UIImage 上添加一层颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28799649/