2011-08-24 63 views
2

我有一個在代碼中設置的箭頭的自定義形狀。我想要做的是用漸變填充它。問題是,我不知道如何用漸變填充非矩形形狀(暗框內的空間)。有任何想法嗎?如何用iOS中的漸變填充用CGPoints定義的形狀?

//Define colours used in drawing 
CGContextRef context = UIGraphicsGetCurrentContext(); 

CGColorRef lightColor = _lightColor.CGColor; 
CGColorRef darkColor = _darkColor.CGColor; 
CGColorRef shadowColor = [UIColor colorWithRed:0.2 green:0.2 
              blue:0.2 alpha:0.5].CGColor; 

//Get label text size to help determine sizes for drawing 
CGSize textSize = [[_titleLabel text] sizeWithFont:[_titleLabel font]]; 

//Set shadow 
CGContextSaveGState(context); 
CGContextSetShadowWithColor(context, CGSizeMake(0, 2), 3.0, shadowColor); 

//Set arrow shape 
CGPoint rectangle_points[] = 
{ 
    CGPointMake(_coloredBoxRect.origin.x, _coloredBoxRect.origin.y), 
    CGPointMake(textSize.width+10, _coloredBoxRect.origin.y), 
    CGPointMake(textSize.width+40, _coloredBoxRect.origin.y+20), 
    CGPointMake(textSize.width+10, _coloredBoxRect.origin.y+40), 
    CGPointMake(_coloredBoxRect.origin.x, _coloredBoxRect.origin.y+40), 
    CGPointMake(_coloredBoxRect.origin.x, _coloredBoxRect.origin.y), 
}; 
CGContextAddLines(context, rectangle_points, 6);  
CGContextSetFillColorWithColor(context, lightColor); 
CGContextFillPath(context); 

CGContextRestoreGState(context); 

//Draw dark frame for the arrow 
CGContextSetStrokeColorWithColor(context, darkColor); 
CGContextSetLineWidth(context, 1.0); 
CGContextSaveGState(context); 
draw1PxStroke(context, CGPointMake(_coloredBoxRect.origin.x, _coloredBoxRect.origin.y), CGPointMake(textSize.width+10, _coloredBoxRect.origin.y), darkColor); 
draw1PxStroke(context, CGPointMake(textSize.width+10, _coloredBoxRect.origin.y+40), CGPointMake(_coloredBoxRect.origin.x, _coloredBoxRect.origin.y+40), darkColor); 
draw1PxStroke(context, CGPointMake(_coloredBoxRect.origin.x, _coloredBoxRect.origin.y), CGPointMake(_coloredBoxRect.origin.x, _coloredBoxRect.origin.y+40), darkColor); 
draw1PxStroke(context, CGPointMake(textSize.width+10, _coloredBoxRect.origin.y), CGPointMake(textSize.width+40, _coloredBoxRect.origin.y+20), darkColor); 
draw1PxStroke(context, CGPointMake(textSize.width+10, _coloredBoxRect.origin.y+40), CGPointMake(textSize.width+40, _coloredBoxRect.origin.y+20), darkColor);  
CGContextRestoreGState(context); 

回答