时间:2021-05-02
如何从A颜色平滑的过渡到B颜色
同一个视图,随着进度或者其他过程的变化,从A颜色过渡到B颜色。
所有的颜色都是是由RGB三原色组成,在iOS开发中,通过RGB值的组合来显示不同的颜色。一次A-B其实就是RGB值的改变,如何平滑的过渡呢?那就是等比例的改变RGB值!
那么,如何获取颜色的RGB值呢?
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 - (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)]; }有了上面的方法,下面就可以计算出连个颜色之间的色差
? 1 2 3 4 5 6 - (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])]; }最后通过过渡系数来返回当前的颜色
? 1 2 3 4 5 6 7 - (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开发中如何实现一个平滑的颜色过渡,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:http://blog.csdn.net/u012478608/article/details/71437328
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
背景:想要实现图片持续滚动,既然使用js,就千万不要加css动画、过渡等相关样式,如果想要滚动的平滑一下,可以一像素一像素的感动,则很平滑,如果加了过渡动画,当
今天我们使用OpenGLES来实现一个绘画板,主要介绍在OpenGLES中绘制平滑曲线的实现方案。首先看一下最终效果:在iOS中,有很多种方式可以实现一个绘画板
Flutter的路由导航路由管理或导航管理:从一个页面平滑地过渡到另一个页面,我们需要有一个统一的机制来管理页面之间的跳转。在原生的Android开发,是通过s
卡拉OK中的字幕随着歌曲的进行会逐渐点亮,由于字幕不是一个一个地点亮而是逐渐过渡,所以我们在网页中实现该效果时,要通过两个层来实现,两个层的文字相同,颜色不同,
页面与页面间平滑过渡,可以让页面展示更加自然,在Office365中可利用平滑过渡轻松解决,该怎么添加这个效果呢?下面我们就来看看详细的教程。软件名称:Offi