IOS: создайте UIImage или UIImageView с закругленными углами

98

Можно ли создать UIImageили UIImageViewсо скругленными углами? Потому что я хочу взять UIImageи показать это внутри UIImageView, но я не знаю, как это сделать.

ВелоспортIsBetter
источник

Ответы:

235

Да, это возможно.
Импортируйте заголовок QuartzCore ( #import <QuartzCore/QuartzCore.h>) и поиграйте со layerсвойством UIImageView.

yourImageView.layer.cornerRadius = yourRadius;
yourImageView.clipsToBounds = YES;

См. Справку по классу CALayer для получения дополнительной информации.

Инькоу
источник
1
хорошо, это работает для UIImageView, но если я вставлю в этот UIImageView UIImage, это не сработает, как я могу решить?
cyclingIsBetter
9
Не забудьте активировать clipToBounds. yourImageView.clipsToBounds = YES;
yinkou
1
Если ImageView находился внутри ячейки scrollView или tableView, clipsToBounds снижает производительность прокрутки.
OzBoz
Я тестирую так! Стоит много памяти!
LE SANG
Я использовал этот код в Swift 2.0, и он работал правильно, спасибо. Кстати, я поменял ДА на истину.
lmiguelvargasf
54

Попробуйте этот код для Round Image Import QuartzCore рамки простого способ создать круглое изображение

imageView.layer.backgroundColor=[[UIColor clearColor] CGColor];
imageView.layer.cornerRadius=20;
imageView.layer.borderWidth=2.0;
imageView.layer.masksToBounds = YES;
imageView.layer.borderColor=[[UIColor redColor] CGColor];

введите описание изображения здесь

Мураликришна
источник
47

Цель-C

-(UIImage *)makeRoundedImage:(UIImage *) image 
                      radius: (float) radius;
{
  CALayer *imageLayer = [CALayer layer];
  imageLayer.frame = CGRectMake(0, 0, image.size.width, image.size.height);
  imageLayer.contents = (id) image.CGImage;

  imageLayer.masksToBounds = YES;
  imageLayer.cornerRadius = radius;

  UIGraphicsBeginImageContext(image.size);
  [imageLayer renderInContext:UIGraphicsGetCurrentContext()];
  UIImage *roundedImage = UIGraphicsGetImageFromCurrentImageContext();
  UIGraphicsEndImageContext();

  return roundedImage;
}

Swift 3

func makeRoundedImage(image: UIImage, radius: Float) -> UIImage {
    var imageLayer = CALayer()
    imageLayer.frame = CGRect(x: 0, y: 0, width: image.size.width, height: image.size.height)
    imageLayer.contents = image.cgImage

    imageLayer.masksToBounds = true
    imageLayer.cornerRadius = radius

    UIGraphicsBeginImageContext(image.size)
    imageLayer.render(in: UIGraphicsGetCurrentContext())
    var roundedImage = UIGraphicsGetImageFromCurrentImageContext()
    UIGraphicsEndImageContext()

    return roundedImage
}
Савас Адар
источник
как сделать центральную часть изображения создать форму кривой тонкой, как реализовать эту концепцию, пожалуйста, парень, дайте мне знать для объективного языка c
Рамани Хитеш
10
uiimageview.layer.cornerRadius = uiimageview.frame.size.height/2;
uiimageview.clipToBounds = YES;

#import <QuartzCore/QuartzCore.h>
Абдул Рехман Батт
источник
2
Чем это отличается от других ответов?
мммммм 03
3
@Mark uiimageview.frame.size.height/2;- настоящая жемчужина, позволяющая придать изображению идеальную круглую форму, полный круг.
Ans
Как вы пришли к uiimageview.frame.size.height / 2? Не могли бы вы объяснить?
Идрис Ашраф,
@IdreesAshraf здесь задействована простая логика .... радиус половинной высоты будет начинаться от верхней середины до левой середины. делая дугу 45 градусов. Таким образом, наличие такой дуги с 4 сторон сделает вид идеальным кругом.
Ответ
1
@Ans Не получится, если у меня есть изображение с разной шириной и высотой. Вы можете попробовать это ..
Идрис Ашраф
3
// UIImageView+OSExt.h
#import <UIKit/UIKit.h>

@interface UIImageView (OSExt)
- (void)setBorder:(CGFloat)borderWidth color:(UIColor*)color;
@end

// UIImageView+OSExt.m
#import "UIImageView+OSExt.h"

@implementation UIImageView (OSExt)
- (void)layoutSublayersOfLayer:(CALayer *)layer
{
    for ( CALayer *sub in layer.sublayers )
    {
        if ( YES == [sub.name isEqual:@"border-shape"])
        {
            CGFloat borderHalf = floor([(CAShapeLayer*)sub lineWidth] * .5);
            sub.frame = layer.bounds;
            [sub setBounds:CGRectInset(layer.bounds, borderHalf, borderHalf)];
            [sub setPosition:CGPointMake(CGRectGetMidX(layer.bounds),
                                       CGRectGetMidY(layer.bounds))];
        }
    }
}

- (void)setBorder:(CGFloat)borderWidth color:(UIColor*)color
{
    assert(self.frame.size.width == self.frame.size.height);
    for ( CALayer *sub in [NSArray arrayWithArray:self.layer.sublayers] )
    {
        if ( YES == [sub.name isEqual:@"border-shape"])
        {
            [sub removeFromSuperlayer];
            break;
        }
    }

    CGFloat borderHalf = floor(borderWidth * .5);
    self.layer.cornerRadius = self.layer.bounds.size.width * .5;

    CAShapeLayer *circleLayer = [CAShapeLayer layer];
    self.layer.delegate = (id<CALayerDelegate>)self;
    circleLayer.name = @"border-shape";
    [circleLayer setBounds:CGRectInset(self.bounds, borderHalf, borderHalf)];
    [circleLayer setPosition:CGPointMake(CGRectGetMidX(self.layer.bounds),
                                         CGRectGetMidY(self.layer.bounds))];
    [circleLayer setPath:[[UIBezierPath bezierPathWithOvalInRect:circleLayer.bounds] CGPath]];
    [circleLayer setStrokeColor:color.CGColor];
    [circleLayer setFillColor:[UIColor clearColor].CGColor];
    [circleLayer setLineWidth:borderWidth];

    {
    circleLayer.shadowOffset = CGSizeZero;
    circleLayer.shadowColor = [[UIColor whiteColor] CGColor];
    circleLayer.shadowRadius = borderWidth;
    circleLayer.shadowOpacity = .9f;
    circleLayer.shadowOffset = CGSizeZero;
    }

    // Add the sublayer to the image view's layer tree
    [self.layer addSublayer:circleLayer];

    // old variant
    //CALayer *layer = self.layer;
    //layer.masksToBounds = YES;
    //layer.cornerRadius = self.frame.size.width * 0.5;
    //layer.borderWidth = borderWidth;
    //layer.borderColor = color;
}
@end

введите описание изображения здесь

Роман Солодяшкин
источник
Похоже, что немного изображения просочилось за границу. Я не уверен, есть ли для этого легкое решение…
Джон Гибб
Граница улучшена
Роман Солодяшкин
2

Настройка cornerRadiusи clipsToBounds- правильный способ сделать это. Однако, если размер представления изменится, радиус не обновится. Чтобы получить правильное поведение при изменении размера и анимации, вам необходимо создать UIImageViewподкласс.

class RoundImageView: UIImageView {
    override var bounds: CGRect {
        get {
            return super.bounds
        }
        set {
            super.bounds = newValue
            setNeedsLayout()
        }
    }

    override func layoutSubviews() {
        super.layoutSubviews()
        layer.cornerRadius = bounds.width / 2.0
        clipsToBounds = true
    }
}
Orkoden
источник
1

Попробуйте это, чтобы получить скругленные углы изображения View, а также раскрасить углы:

imageView.layer.cornerRadius = imageView.frame.size.height/2;
imageView.layer.masksToBounds = YES;
imageView.layer.borderColor = [UIColor colorWithRed:148/255. green:79/255. blue:216/255. alpha:1.0].CGColor;
imageView.layer.borderWidth=2;

Условие *: высота и ширина imageView должны быть одинаковыми, чтобы углы были закруглены.

Md Rais
источник
1
  1. layer.cornerRadius = imageviewHeight / 2

  2. layer.masksToBounds = true

Маниш Махаджан
источник
0

Это возможно, но я советую вам создать прозрачное png-изображение (маску) с закругленными углами и разместить его поверх вашего изображения с помощью UIImageView. Это может быть более быстрое решение (например, если вам нужна анимация или прокрутка).

Ник
источник
0

Вот как я установил свой скругленный аватар в центре, содержащий представление:

-(void)setRoundedAvatar:(UIImageView *)avatarView toDiameter:(float)newSize atView:(UIView *)containedView;
{
    avatarView.layer.cornerRadius = newSize/2;
    avatarView.clipsToBounds = YES;

    avatarView.frame = CGRectMake(0, 0, newSize, newSize);
    CGPoint centerValue = CGPointMake(containView.frame.size.width/2, containedView.frame.size.height/2);
    avatarView.center = centerValue;
}
привет
источник
0

Круг с UIBeizerPath # Swift-3 && #imageExtension

class ViewController: UIViewController {
    @IBOutlet weak var imageOutlet: UIImageView!
    override func viewDidLoad() {
        super.viewDidLoad()
        let image = UIImage(named: "IMG_0001.JPG")
        if let image = image {
            let renderimage = image.imageCroppingBezierPath(path: UIBezierPath(arcCenter: CGPoint(x:image.size.width/2,y:image.size.width/2 )  , radius: 200, startAngle: 0, endAngle:  (2 * CGFloat(M_PI) ), clockwise: true) )
                imageOutlet.image = renderimage
        }
    }
}


extension UIImage {
    func imageCroppingBezierPath(path:UIBezierPath) ->UIImage {

        let frame = CGRect(x: 0, y: 0, width: self.size.width, height: self.size.height)

        //Defining a graphic context  to paint on
        UIGraphicsBeginImageContextWithOptions(self.size, false, 0.0)
        //Get the current graphics context (if it exists)
        let context = UIGraphicsGetCurrentContext()
        //save the current graphic context
        context?.saveGState()
        // clipping area
        path.addClip()
        self.draw(in: frame)

        //To extract an image from our canvas
        let image = UIGraphicsGetImageFromCurrentImageContext()
        //restore graphic context
        context?.restoreGState()
        //remove current context from stack
        UIGraphicsEndImageContext()
        return image!
    }
}
Шраван
источник
-1
# import QuartzCore framework
imageView.layer.cornerRadius=imgvwUser.frame.size.width/2;
imageView.layer.masksToBounds = YES;

Высота и ширина imageView должны быть одинаковыми, чтобы углы были закруглены.

tania_S
источник