如何在IOS开发中实现平滑的颜色过渡
来源:爱站网时间:2021-01-19编辑:网友分享
IOS开发中的个人中心通常都没有导航栏,这个操作可以让导航栏透明化,那么如何在IOS开发中实现平滑的颜色过渡,大家学会了吗?别着急,跟随爱站技术频道一起了解下吧。
IOS开发中的个人中心通常都没有导航栏,这个操作可以让导航栏透明化,那么如何在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*beginColorArr = [self getRGBDictionaryByColor:beginColor]; // NSArray *endColorArr = [self getRGBDictionaryByColor:endColor]; NSArray *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*)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开发中实现平滑的颜色过渡,项目的开发都是值得大家重视的,赶紧跟着小编的步伐操作起来吧!