iphone - 在圆形 UIImageView 后面创建阴影时出现问题

标签 iphone objective-c uiimageview core-animation calayer

我有一个圆形的 UIImageView。当我给它添加阴影时,我失去了圆角。我怎样才能有带圆角的阴影?

//Avatar
        CGRect rect;
        rect = CGRectMake(13, 10, 48, 48);
        avatarImageView = [[TCImageView alloc] initWithURL:[NSURL URLWithString:nil] placeholderImage:[UIImage imageNamed:@"placeholder.png"]];
        avatarImageView.frame = rect;
        avatarImageView.caching = YES;

        //Round the corners
        CALayer * layer = [avatarImageView layer];
        [layer setMasksToBounds:YES];
        [layer setCornerRadius:9.0];

        //Add a shadow
        avatarImageView.layer.shadowColor = [UIColor grayColor].CGColor;
        avatarImageView.layer.shadowOffset = CGSizeMake(0, 1);
        avatarImageView.layer.shadowOpacity = 1;
        avatarImageView.layer.shadowRadius = 9.0;
        avatarImageView.clipsToBounds = NO;

        [self.contentView addSubview: avatarImageView];

最佳答案

使您的图像显示圆角的功能是隐藏阴影的功能:[layer setMasksToBounds: YES]。您可以做的是,将您的 ImageView 放在 UIView subview 中,该 subview 充当提供阴影的容器。

所以代码可能看起来像这样(我只是把它打下来,虽然没有编译它)

//Avatar
CGRect rect;
rect = CGRectMake(13, 10, 48, 48);
avatarImageView = [[TCImageView alloc] initWithURL:[NSURL URLWithString:nil]   placeholderImage:[UIImage imageNamed:@"placeholder.png"]];
avatarImageView.frame = rect;
avatarImageView.caching = YES; 

//Round the corners
CALayer * layer = [avatarImageView layer];
[layer setMasksToBounds:YES];
[layer setCornerRadius:9.0];

//Add a shadow by wrapping the avatar into a container
UIView * container = [[UIView alloc] initWithFrame: rect];
avatarImageView.frame = CGRectMake(0,0,rect.size.width, rect.size.height);

// setup shadow layer and corner
container.layer.shadowColor = [UIColor grayColor].CGColor;
container.layer.shadowOffset = CGSizeMake(0, 1);
container.layer.shadowOpacity = 1;
container.layer.shadowRadius = 9.0;
container.layer.cornerRadius = 9.0;
container.clipsToBounds = NO;

// combine the views
[container addSubview: avatarImageView];
[self.contentView addSubview: container];
[container release];

关于iphone - 在圆形 UIImageView 后面创建阴影时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6476692/

相关文章:

iphone - 如何将 30000 x 6000 的图像平铺到 480 x 320 的屏幕上?

iphone - 当目标对象已经为 NULL 时,iOS 如何捕获发送到实例的无法识别的选择器异常?

objective-c - 裁剪后的 UIImageView 在设备上显示错误

ios - 尝试将 react-native 应用程序与现有 ios 应用程序集成时出现 "_fbBatchedBridge is undefined"错误

iphone - 为 UITableView 的第一个和最后一个单元格制作圆角

objective-c - CGImageCreateWithJPEGDataProvider 线程安全与否?

ios - 如何将图像添加到 TableView Controller

iphone - 如何在更改 UIImageView 时制作动画

ios - 通过 UIImagepickerController 从相机中选取图像并保存到 ios 中的相册后获取图像名称

ios - 在单个 ViewController 上使用多个 Tableview