iOS开发中如何实现一个平滑的颜色过渡

 更新时间:2017年05月09日 09:51:36   作者:进击的_superman  
这篇文章给大家分享在ios开发中如何从a颜色平滑的过渡到b颜色。代码简单易懂,需要的朋友参考下吧

如何从A颜色平滑的过渡到B颜色

同一个视图,随着进度或者其他过程的变化,从A颜色过渡到B颜色。

所有的颜色都是是由RGB三原色组成,在iOS开发中,通过RGB值的组合来显示不同的颜色。一次A-B其实就是RGB值的改变,如何平滑的过渡呢?那就是等比例的改变RGB值!

那么,如何获取颜色的RGB值呢?

- (NSArray *)getRGBDictionaryByColor:(UIColor *)originColor
{
  CGFloat r=0,g=0,b=0,a=0;
  if ([self respondsToSelector:@selector(getRed:green:blue:alpha:)]) {
    [originColor getRed:&r green:&g blue:&b alpha:&a];
  }
  else {
    const CGFloat *components = CGColorGetComponents(originColor.CGColor);
    r = components[0];
    g = components[1];
    b = components[2];
    a = components[3];
  }
  return @[@(r),@(g),@(b)];
}

有了上面的方法,下面就可以计算出连个颜色之间的色差

- (NSArray *)transColorBeginColor:(UIColor *)beginColor andEndColor:(UIColor *)endColor {
  NSArray<NSNumber *> *beginColorArr = [self getRGBDictionaryByColor:beginColor];
//  NSArray<NSNumber *> *endColorArr = [self getRGBDictionaryByColor:endColor];
  NSArray<NSNumber *> *endColorArr = @[@(1.0),@(1.0),@(1.0)];
  return @[@([endColorArr[0] doubleValue] - [beginColorArr[0] doubleValue]),@([endColorArr[1] doubleValue] - [beginColorArr[1] doubleValue]),@([endColorArr[2] doubleValue] - [beginColorArr[2] doubleValue])];
}

最后通过过渡系数来返回当前的颜色

- (UIColor *)getColorWithColor:(UIColor *)beginColor andCoe:(double)coe andMarginArray:(NSArray<NSNumber *> *)marginArray {
  NSArray *beginColorArr = [self getRGBDictionaryByColor:beginColor];
  double red = [beginColorArr[0] doubleValue] + coe * [marginArray[0] doubleValue];
  double green = [beginColorArr[1] doubleValue]+ coe * [marginArray[1] doubleValue];
  double blue = [beginColorArr[2] doubleValue] + coe * [marginArray[2] doubleValue];
  return RGBNUM(red, green, blue);
}

把获取到的颜色赋值给相应的控件,这样便完成了一个颜色过渡的效果。

以上所述是小编给大家介绍的iOS开发中如何实现一个平滑的颜色过渡,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • iOS开发中使用UIScrollView实现图片轮播和点击加载

    iOS开发中使用UIScrollView实现图片轮播和点击加载

    这篇文章主要介绍了iOS开发中使用UIScrollView实现图片轮播和点击加载的方法,代码基于传统的Objective-C,需要的朋友可以参考下
    2015-12-12
  • iOS中的UITextView文字输入光标使用技巧小结

    iOS中的UITextView文字输入光标使用技巧小结

    UITextView在用户体验方面有着十分明显的作用,包括键盘的呼出及文字的选择等,接下来就来整理给出一份iOS中的UITextView文字输入光标使用技巧小结,需要的朋友可以参考下
    2016-05-05
  • iOS Moya实现OAuth请求的方法

    iOS Moya实现OAuth请求的方法

    这篇文章主要介绍了iOS Moya实现OAuth请求的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-12-12
  • iOS小数取整的方法(ceil floor round)示例

    iOS小数取整的方法(ceil floor round)示例

    这篇文章主要为大家介绍了iOS小数取整的方法(ceil floor round)示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • iOS中使用UIDatePicker制作时间选择器的实例教程

    iOS中使用UIDatePicker制作时间选择器的实例教程

    这篇文章主要介绍了iOS中使用UIDatePicker制作时间选择器的实例教程,实例中未选中的时间项目会讲解一个将其变透明的方法,非常给力,需要的朋友可以参考下
    2016-05-05
  • 键盘弹出时会覆盖文本框怎么解决

    键盘弹出时会覆盖文本框怎么解决

    在一些网站登陆界面,我们经常会见到,键盘的出现与隐藏操作,那么基于代码是如何实现的呢?下面小编写了具体代码介绍,特此分享到脚本之家平台,供大家参考
    2016-04-04
  • iOS中设置view圆角化的四种方法示例

    iOS中设置view圆角化的四种方法示例

    最近因为工作的原因,遇到view圆角优化的问题,所以将实现的几种方法总结分享出来,下面这篇文章主要给大家介绍了关于iOS中设置view圆角化的四种方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2017-09-09
  • iOS贝塞尔曲线画哆啦A梦的代码实例

    iOS贝塞尔曲线画哆啦A梦的代码实例

    本篇文章主要介绍了iOS贝塞尔曲线画哆啦A梦的代码实例,这里整理了详细的代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-07-07
  • iOS实现容器视图控制器的方法

    iOS实现容器视图控制器的方法

    本篇文章给大家详细讲述了iOS实现容器视图控制器的方法,对此感兴趣的朋友可以测试学习下。
    2018-02-02
  • iOS 对当前webView进行截屏的方法

    iOS 对当前webView进行截屏的方法

    下面小编就为大家带来一篇iOS 对当前webView进行截屏的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04

最新评论