我需要椭圆形或椭圆形的径向渐变,看起来 CGContextDrawRadialGradient 只能画一个完美的圆。我一直在绘制方形上下文,然后复制/绘制到矩形上下文中。
有没有更好的方法来做到这一点?
谢谢!
我需要椭圆形或椭圆形的径向渐变,看起来 CGContextDrawRadialGradient 只能画一个完美的圆。我一直在绘制方形上下文,然后复制/绘制到矩形上下文中。
有没有更好的方法来做到这一点?
谢谢!
我发现这样做的唯一方法是按照 Mark F 的建议,但我认为答案需要一个更容易理解的例子。
在 iOS 的视图中绘制椭圆渐变(并使用 ARC):
- (void)drawRect:(CGRect)rect {
CGContextRef ctx = UIGraphicsGetCurrentContext();
// Create gradient
CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();
CGFloat locations[] = {0.0, 1.0};
UIColor *centerColor = [UIColor orangeColor];
UIColor *edgeColor = [UIColor purpleColor];
NSArray *colors = [NSArray arrayWithObjects:(__bridge id)centerColor.CGColor, (__bridge id)edgeColor.CGColor, nil];
CGGradientRef gradient = CGGradientCreateWithColors(colorSpace, (__bridge CFArrayRef)colors, locations);
// Scaling transformation and keeping track of the inverse
CGAffineTransform scaleT = CGAffineTransformMakeScale(2, 1.0);
CGAffineTransform invScaleT = CGAffineTransformInvert(scaleT);
// Extract the Sx and Sy elements from the inverse matrix
// (See the Quartz documentation for the math behind the matrices)
CGPoint invS = CGPointMake(invScaleT.a, invScaleT.d);
// Transform center and radius of gradient with the inverse
CGPoint center = CGPointMake((self.bounds.size.width / 2) * invS.x, (self.bounds.size.height / 2) * invS.y);
CGFloat radius = (self.bounds.size.width / 2) * invS.x;
// Draw the gradient with the scale transform on the context
CGContextScaleCTM(ctx, scaleT.a, scaleT.d);
CGContextDrawRadialGradient(ctx, gradient, center, 0, center, radius, kCGGradientDrawsBeforeStartLocation);
// Reset the context
CGContextScaleCTM(ctx, invS.x, invS.y);
// Continue to draw whatever else ...
// Clean up the memory used by Quartz
CGGradientRelease(gradient);
CGColorSpaceRelease(colorSpace);
}
放入一个黑色背景的视图,你会得到:
您可以更改上下文的变换以绘制椭圆(例如,在调用 CGContextDrawRadialGradient () 之前应用 CGContextScaleCTM(context, 2.0, 1.0) 以绘制宽度为高度两倍的椭圆渐变)。不过,请记住将逆变换应用于您的起点和终点。