ios - 在 UIImage 上添加一层颜色

标签 ios swift ios8 xcode6

我希望在点击时让我的 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/

相关文章:

iOS MapView 在 vi​​sibleRect 中显示当前位置和注释

ios - 如何在单击添加按钮时动态添加新的文本字段

ios - 将用户名和密码保存在钥匙串(keychain)中并将其用作自动填充

json - 解析一些网站数据(SWIFT/JSON)

Swift:避免命令式 For 循环

xcodebuild 无法从终端构建,但从 xcode 成功构建

ios - 验证 IOS 应用程序存档

iOS Swift - 计算两次之间的差异

xcode - Scenekit如何在不同位置有X数量的矩形?

swift - 无法在 Storyboard上移动自定义 UIView