1

I'm trying to create a "mini-map." It's a circle filled with markers, and I want the border of the circle to glow in places to indicate to the user to indicate that more markers are beyond the minimap in a given direction.

I can give the circle a 'glowing' blue border by drawing, below it, a blue circle with a slightly larger radius. I think that I can make this blue border brighter in some places than others by giving its CALayer a mask. (I've tried giving it a gradient mask, and it works.)

Assuming that I can make the proper calculations to determine how bright a given pixel should be (given the position of markers beyond the minimap's viewport), how do I set the individual pixels of a CALayer? Or is there an easier way to accomplish what I'm looking for besides making a complicated alpha value calculation for each pixel in the circle?

Thanks.

4

2 回答 2

1

这是我的解决方案。我画了一系列 1 像素的弧线,每个弧线都有不同的描边颜色。

void AddGlowArc(CGContextRef context, CGFloat x, CGFloat y, CGFloat radius, CGFloat peakAngle, CGFloat sideAngle, CGColorRef colorRef){
    CGFloat increment = .05;
    for (CGFloat angle = peakAngle - sideAngle; angle < peakAngle + sideAngle; angle+=increment){
        CGFloat alpha = (sideAngle - fabs(angle - peakAngle)) / sideAngle;
        CGColorRef newColor = CGColorCreateCopyWithAlpha(colorRef, alpha);
        CGContextSetStrokeColorWithColor(context, newColor);
        CGContextAddArc(context, x, y, radius, angle, angle + increment, 0);
        CGContextStrokePath(context);
    }
}

然后,在 DrawRect 中,

CGContextRef context = UIGraphicsGetCurrentContext();
CGContextSetLineWidth(context, 2.0);
AddGlowArc(context, 160, 160, 160, angle, .2, [UIColor colorWithRed:0 green:.76 blue:.87 alpha:1].CGColor);
于 2013-05-29T01:14:17.543 回答
0

这是我的 [更长] 解决方案,如果需要,可以单独添加每个发光点图层并为其设置动画。将小圆圈添加到较大圆圈的圆周上,然后旋转较大的圆圈。即使你回答了这个问题,我也很高兴能解决这个问题

- (void)viewDidLoad
{
    [super viewDidLoad];
    CGPoint circleCenter = CGPointMake(300.f, 300.f);
    CALayer *outerCircle = [self outerCircleToRotateWithCenter:circleCenter andRadius:100.f];
    [self.view.layer addSublayer:outerCircle];

    CGFloat rotationAngleInDeg = 270.f;
    CGFloat rotationAngle = (M_PI * -rotationAngleInDeg)/180.f;

    CATransform3D transform = CATransform3DIdentity;
    transform = CATransform3DRotate(transform, rotationAngle, 0.f, 0.f, -1.f);
    [outerCircle setTransform:transform];
}

使用方法:

- (CALayer *)outerCircleToRotateWithCenter:(CGPoint)circleCenter andRadius:(CGFloat )radius {
    // outer circle
    CAShapeLayer *container = [CAShapeLayer layer];
    UIBezierPath *containerCircle = [UIBezierPath
                            bezierPathWithOvalInRect:CGRectMake(0.f, 0.f, radius, radius)];
    [container setPath:containerCircle.CGPath];
    [container setBounds:CGPathGetBoundingBox(containerCircle.CGPath)];
    [container setPosition:circleCenter];
    [container setAnchorPoint:CGPointMake(0.5f, 0.5f)];
    [container setStrokeColor:[UIColor blackColor].CGColor]; // REMOVE
    [container setFillColor:nil];

    // smaller circle
    CAShapeLayer *circle = [[CAShapeLayer alloc] init];
    [container addSublayer:circle];
    UIBezierPath *circlePath = [UIBezierPath
                            bezierPathWithOvalInRect:CGRectMake(0.f, 0.f, 25.f, 25.f)];
    [circle setPath:circlePath.CGPath];
    [circle setBounds:CGPathGetBoundingBox(circlePath.CGPath)];
    [circle setFillColor:[UIColor orangeColor].CGColor];
    [circle setAnchorPoint:CGPointMake(0.5f, 0.5f)];
    [circle setPosition:CGPointMake(radius/2.f, 0.f)];
    [circle setOpacity:0.4f];

    // shadow
    [circle setShadowOpacity:0.8f];
    [circle setShadowRadius:4.f];
    [circle setShadowOffset:CGSizeMake(0.f, 0.f)];
    [circle setShadowColor:[UIColor orangeColor].CGColor];
    [circle setShadowPath:circlePath.CGPath];

    return container;
}

我猜可以在单个变换中添加和旋转较小的圆圈,而不是作为子层。

于 2013-05-27T07:41:57.133 回答