typedef NS_ENUM(NSInteger, UIViewContentMode) {
// 默认属性,缩放图片至图片填充整个UIImageView
UIViewContentModeScaleToFill,
// 按照"图片的宽高"比例缩放图片至图片的宽度或者高度和UIImageView一样,并且让整个图片都在UIImageView中,然后居中显示
UIViewContentModeScaleAspectFit, // contents scaled to fit with fixed aspect. remainder is transparent
// 按照"图片的宽高"比例缩放图片至图片的宽度和高度填充整个UIImageView,然后居中显示,图片可能会溢出
UIViewContentModeScaleAspectFill, // contents scaled to fill with fixed aspect. some portion of content may be clipped.
// 调用setNeedsDisplay方法时,就会重新渲染图片
UIViewContentModeRedraw, // redraw on bounds change (calls -setNeedsDisplay)
UIViewContentModeCenter, // contents remain same size. positioned adjusted.
UIViewContentModeTop,
UIViewContentModeBottom,
UIViewContentModeLeft,
UIViewContentModeRight,
UIViewContentModeTopLeft,
UIViewContentModeTopRight,
UIViewContentModeBottomLeft,
UIViewContentModeBottomRight,
};
Summary:
- 凡是带有Scale单词的属性,图片都会被拉伸或压缩。
- 凡是带有Ascept单词(n.外貌、方面)属性,图片会保持原来的宽高比,即图片不会变形。
1. UIViewContentModeScaleToFill
默认填充模式,将图片拉伸或者压缩至充满整个容器。
data:image/s3,"s3://crabby-images/05848/058484661b102d864f9c9fd01fbacd65ddb4d7e0" alt=""
2. UIViewContentModeScaleAspectFit
图片并没有变形,等比例缩放至父容器完全装下图片为止。
data:image/s3,"s3://crabby-images/06d9f/06d9f133cc82e11c3ff11860b0023734aea9b93b" alt=""
3. UIViewContentModeScaleAspectFill
图片拉伸后居中显示,宽度或者高度拉伸到了与父容器的宽度或者高度相等,图片并没有变形,但超出了父容器的范围。
用.clipsToBounds = YES;可以使图片占满整个父容器,并且不变形。
data:image/s3,"s3://crabby-images/c93b2/c93b21f7d60fd3a5258aa36344df48ecc9618d49" alt=""
4. UIViewContentModeLeft
图片居左显示。
data:image/s3,"s3://crabby-images/46c52/46c5261c88784cf278484ac388f9b653fe4c73f4" alt=""
网友评论