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

如何从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开发中如何实现一个平滑的颜色过渡
文章来源:https://www.cdcxhl.com/article44/pieoee.html

成都网站建设公司_创新互联,为您提供网站导航服务器托管网站制作商城网站电子商务

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

微信小程序开发