ObjectC&&Swift 渐变色算法实现

前端之家收集整理的这篇文章主要介绍了ObjectC&&Swift 渐变色算法实现前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
  1. -(NSArray *)getGradientColorWithStartColor:(UIColor *)startColor endColor:(UIColor *)endColor step:(NSInteger)step inverse:(BOOL)inverse {
  2. //1 get start color rgb
  3. CGFloat startR = 0.0,startG = 0.0,startB = 0.0;
  4. CGColorRef startColorRGB = [startColor CGColor];
  5. NSInteger startNumComponents = CGColorGetNumberOfComponents(startColorRGB);
  6. if (startNumComponents == 4)
  7. {
  8. const CGFloat *components = CGColorGetComponents(startColorRGB);
  9. startR = components[0];
  10. startG = components[1];
  11. startB = components[2];
  12. }
  13. //2 get end color rgb
  14. CGFloat endR = 0.0,endG = 0.0,endB = 0.0;
  15. CGColorRef endColorRGB = [endColor CGColor];
  16. NSInteger endNumComponents = CGColorGetNumberOfComponents(endColorRGB);
  17. if (endNumComponents == 4)
  18. {
  19. const CGFloat *components = CGColorGetComponents(endColorRGB);
  20. endR = components[0];
  21. endG = components[1];
  22. endB = components[2];
  23. }
  24. //3 calculate total threshold by step
  25. CGFloat stepR = 0.0,stepG = 0.0,stepB = 0.0;
  26. stepR = step == 1 ? 0 : (endR-startR) / (step - 1);
  27. stepG = step == 1 ? 0 : (endG-startG) / (step - 1);
  28. stepB = step == 1 ? 0 : (endB-startB) / (step - 1);
  29. //calculate uicolor by step
  30. CGFloat green = startG;
  31. CGFloat red = startR;
  32. CGFloat blue = startB;
  33. NSMutableArray *stepColorArray = [[NSMutableArray alloc] initWithCapacity:step];
  34. for (NSInteger i = 0; i < step - 1; i++) {
  35. red = red + stepR;
  36. green = green + stepG;
  37. blue = green + stepB;
  38. UIColor *color = [UIColor colorWithRed:red green:green blue:blue alpha:0];
  39. [stepColorArray addObject:color];
  40. }
  41. return stepColorArray;
  42. }

猜你在找的Swift相关文章