Добавить закругленные углы в UIImage? - PullRequest
3 голосов
/ 15 ноября 2011

Я знаю, что можно иметь закругленные углы на объектах, таких как UIImageView (я делал это раньше). Но в этом случае мне нужно иметь свое квадратное UIImage, чтобы иметь закругленные углы. Я знаю, что это сложнее, чем просто сделать это с объектом, но мне это нужно специально для UIImage.

Может ли кто-нибудь поделиться методом, который не является статичным и может быть реализован в классе, который я уже создал?

Я должен сделать это для UIImage, если только в CCSprite невозможно добавить закругленные края.

Спасибо!

Edit2:

    void addRoundedRectToPath(CGContextRef context, CGRect rect, float ovalWidth, float ovalHeight)
{
    float fw, fh;
    if (ovalWidth == 0 || ovalHeight == 0) {
        CGContextAddRect(context, rect);
        return;
    }
    CGContextSaveGState(context);
    CGContextTranslateCTM (context, CGRectGetMinX(rect), CGRectGetMinY(rect));
    CGContextScaleCTM (context, ovalWidth, ovalHeight);
    fw = CGRectGetWidth (rect) / ovalWidth;
    fh = CGRectGetHeight (rect) / ovalHeight;
    CGContextMoveToPoint(context, fw, fh/2);
    CGContextAddArcToPoint(context, fw, fh, fw/2, fh, 1);
    CGContextAddArcToPoint(context, 0, fh, 0, fh/2, 1);
    CGContextAddArcToPoint(context, 0, 0, fw/2, 0, 1);
    CGContextAddArcToPoint(context, fw, 0, fw, fh/2, 1);
    CGContextClosePath(context);
    CGContextRestoreGState(context);
}

-(UIImage *)makeRoundCornerImage : (UIImage*) img : (int) cornerWidth : (int) cornerHeight
{
    UIImage * newImage = nil;

    if( nil != img)
    {
        NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
        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, img.size.width, img.size.height);
        addRoundedRectToPath(context, rect, cornerWidth, cornerHeight);
        CGContextClosePath(context);
        CGContextClip(context);

        CGContextDrawImage(context, CGRectMake(0, 0, w, h), img.CGImage);

        CGImageRef imageMasked = CGBitmapContextCreateImage(context);
        CGContextRelease(context);
        CGColorSpaceRelease(colorSpace);
        [img release];

        newImage = [[UIImage imageWithCGImage:imageMasked] retain];
        CGImageRelease(imageMasked);

        [pool release];
    }

    return newImage;
}

1 Ответ

6 голосов
/ 15 ноября 2011

Используйте https://stackoverflow.com/a/8125604/412916 для обрезки с UIBezierPath вместо этого.Это проще.

Используя код, указанный выше: http://blog.sallarp.com/iphone-uiimage-round-corners/

// rounded corner 10x10
UIImage *original = [UIImage imageNamed:@"original.png"];
UIImage *rounded = [self makeRoundCornerImage:original :10 :10];

...