Ich habe die Antwort unter Wie erstelle ich ein UILabel mit runden Ecken auf dem iPhone? und der Code von Wie wird eine abgerundete rechte Ansicht mit Transparenz auf dem iPhone erstellt? um diesen Code zu machen.
Dann wurde mir klar, dass ich die falsche Frage beantwortet hatte (gab ein abgerundetes UILabel anstelle von UIImage), also habe ich diesen Code verwendet, um ihn zu ändern:
http://discussions.apple.com/thread.jspa?threadID=1683876
Erstellen Sie ein iPhone-Projekt mit der Ansichtsvorlage. Fügen Sie im Ansichts-Controller Folgendes hinzu:
- (void)viewDidLoad
{
CGRect rect = CGRectMake(10, 10, 200, 100);
MyView *myView = [[MyView alloc] initWithFrame:rect];
[self.view addSubview:myView];
[super viewDidLoad];
}
MyView
ist nur eine UIImageView
Unterklasse:
@interface MyView : UIImageView
{
}
Ich hatte noch nie Grafikkontexte verwendet, aber ich habe es geschafft, diesen Code zusammen zu humpeln. Es fehlt der Code für zwei der Ecken. Wenn Sie den Code lesen, können Sie sehen, wie ich dies implementiert habe (indem Sie einige der CGContextAddArc
Aufrufe und einige der Radiuswerte im Code löschen. Der Code für alle Ecken ist vorhanden. Verwenden Sie ihn also als Ausgangspunkt und löschen Sie den Code Teile, die Ecken erstellen, die Sie nicht benötigen. Beachten Sie, dass Sie bei Bedarf auch Rechtecke mit 2 oder 3 abgerundeten Ecken erstellen können.
Der Code ist nicht perfekt, aber ich bin sicher, Sie können ihn ein wenig aufräumen.
static void addRoundedRectToPath(CGContextRef context, CGRect rect, float radius, int roundedCornerPosition)
{
// all corners rounded
// CGContextMoveToPoint(context, rect.origin.x, rect.origin.y + radius);
// CGContextAddLineToPoint(context, rect.origin.x, rect.origin.y + rect.size.height - radius);
// CGContextAddArc(context, rect.origin.x + radius, rect.origin.y + rect.size.height - radius,
// radius, M_PI / 4, M_PI / 2, 1);
// CGContextAddLineToPoint(context, rect.origin.x + rect.size.width - radius,
// rect.origin.y + rect.size.height);
// CGContextAddArc(context, rect.origin.x + rect.size.width - radius,
// rect.origin.y + rect.size.height - radius, radius, M_PI / 2, 0.0f, 1);
// CGContextAddLineToPoint(context, rect.origin.x + rect.size.width, rect.origin.y + radius);
// CGContextAddArc(context, rect.origin.x + rect.size.width - radius, rect.origin.y + radius,
// radius, 0.0f, -M_PI / 2, 1);
// CGContextAddLineToPoint(context, rect.origin.x + radius, rect.origin.y);
// CGContextAddArc(context, rect.origin.x + radius, rect.origin.y + radius, radius,
// -M_PI / 2, M_PI, 1);
// top left
if (roundedCornerPosition == 1) {
CGContextMoveToPoint(context, rect.origin.x, rect.origin.y + radius);
CGContextAddLineToPoint(context, rect.origin.x, rect.origin.y + rect.size.height - radius);
CGContextAddArc(context, rect.origin.x + radius, rect.origin.y + rect.size.height - radius,
radius, M_PI / 4, M_PI / 2, 1);
CGContextAddLineToPoint(context, rect.origin.x + rect.size.width,
rect.origin.y + rect.size.height);
CGContextAddLineToPoint(context, rect.origin.x + rect.size.width, rect.origin.y);
CGContextAddLineToPoint(context, rect.origin.x, rect.origin.y);
}
// bottom left
if (roundedCornerPosition == 2) {
CGContextMoveToPoint(context, rect.origin.x, rect.origin.y);
CGContextAddLineToPoint(context, rect.origin.x, rect.origin.y + rect.size.height);
CGContextAddLineToPoint(context, rect.origin.x + rect.size.width,
rect.origin.y + rect.size.height);
CGContextAddLineToPoint(context, rect.origin.x + rect.size.width, rect.origin.y);
CGContextAddLineToPoint(context, rect.origin.x + radius, rect.origin.y);
CGContextAddArc(context, rect.origin.x + radius, rect.origin.y + radius, radius,
-M_PI / 2, M_PI, 1);
}
// add the other corners here
CGContextClosePath(context);
CGContextRestoreGState(context);
}
-(UIImage *)setImage
{
UIImage *img = [UIImage imageNamed:@"my_image.png"];
int w = img.size.width;
int h = img.size.height;
CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();
CGContextRef context = CGBitmapContextCreate(NULL, w, h, 8, 4 * w, colorSpace, kCGImageAlphaPremultipliedFirst);
CGContextBeginPath(context);
CGRect rect = CGRectMake(0, 0, w, h);
addRoundedRectToPath(context, rect, 50, 1);
CGContextClosePath(context);
CGContextClip(context);
CGContextDrawImage(context, rect, img.CGImage);
CGImageRef imageMasked = CGBitmapContextCreateImage(context);
CGContextRelease(context);
CGColorSpaceRelease(colorSpace);
[img release];
return [UIImage imageWithCGImage:imageMasked];
}
Alternativtext http://nevan.net/skitch/skitched-20100224-092237.png
Vergessen Sie nicht, dass Sie das QuartzCore-Framework benötigen, damit dies funktioniert.