swift学习笔记-UI篇之UIImageView
2016-02-23 本文已影响3957人
LJCoder
<h3>1.基本使用</h3>
将要使用的图片拖入到项目里,我这里使用的是名为“1.jpg”的图片,然后创建UIImageView,并设置要显示的图片为"1.jpg"
//1. 基本使用
let imageView = UIImageView(frame: CGRectMake(100, 10, 200, 200))
imageView.image = UIImage(named:"1.jpg")
self.view.addSubview(imageView)
<h3>2.UIImageView的用户交互</h3>
UIImageView的用户交互默认是关闭的,也就是说添加到ImageView上的事件都不会响应,需要我们手动设置userInteractionEnabled属性为真,我们给UIImageVIew添加一个点击手势来测试一下,如果注释掉第一行,点击就会失去反应
//2. 用户交互
imageView.userInteractionEnabled = true
let tap = UITapGestureRecognizer(target: self, action: Selector("tapAction:"))
imageView.addGestureRecognizer(tap)
func tapAction(tap :UITapGestureRecognizer) {
let scale :CGFloat = 1.2
var frame = tap.view!.frame
frame = CGRectMake(frame.origin.x * scale, frame.origin.y * scale, frame.size.width * scale, frame.size.height * scale)
tap.view!.frame = frame
}
<h3>3.图片拉伸</h3>
- 整张图片拉伸
为了便于区分,我们给self.view一个红色背景,imageView为绿色,同时改变imageView的高度为300。原图尺寸为136 × 94
//1) 图片整体拉伸
self.view.backgroundColor = UIColor.redColor()
imageView.backgroundColor = UIColor.greenColor()
var frame = imageView.frame
frame = CGRectMake(frame.origin.x, frame.origin.y, frame.size.width, 300)
imageView.frame = frame
// 设置拉伸模式
/*
ScaleToFill: 填充模式,图片不会保持原来的比例
ScaleAspectFit: 图片保持原来的比例,宽度填充,高度自适应
ScaleAspectFill: 图片保持原来的比例,高度填充,宽度自适应
*/
imageView.contentMode = UIViewContentMode.ScaleAspectFit
图片拉伸模式比较
- 部分拉伸
部分拉伸的原理:通过UIEdgeInsets设置拉伸区域,通过减去top、left、bottom、right的距离,得到的中间区域就是拉伸区域。通过平铺拉伸区域或者拉伸拉伸区域来实现部分拉伸。具体计算请看resizableImageWithCapInsets:方法的探析
//2) 部分拉伸
let imageView2 = UIImageView(frame: CGRectMake(10, 320, 200, 94))
// imageView2.image = UIImage(named: "qipao.png")
imageView2.backgroundColor = UIColor.greenColor()
self.view.addSubview(imageView2)
// 设置拉伸
// stretch:通过拉伸来填充
imageView2.image = UIImage(named: "qipao.png")!.resizableImageWithCapInsets(UIEdgeInsetsMake(52, 40, 36, 64), resizingMode: UIImageResizingMode.Stretch)
// tile:通过重复来填充
// imageView2.image = UIImage(named: "qipao.png")!.resizableImageWithCapInsets(UIEdgeInsetsMake(52, 40, 36, 64), resizingMode: UIImageResizingMode.Tile)
<h3>4.图片动画</h3>
先把动画素材导入到项目,创建数组读取图片,再赋值给imageView的animationImages属性,分别设置好动画时间和循环次数后开启动画
//4. 图片动画
// 创建UIimage数组,数组每个元素为一帧
let animationImages = NSMutableArray()
for var i = 1; i <= 40; i++ {
let image = UIImage(named: "v\(i).jpg")
animationImages.addObject(image!)
}
let array = animationImages as Array as? [UIImage]
// 设置animationImages
imageView.animationImages = array
// 设置动画时间
imageView.animationDuration = 9
// 设置动画循环次数,0为无限循环
imageView.animationRepeatCount = 0
// 开启动画
imageView.startAnimating()
<h3>5.源码下载</h3>
https://github.com/ljcoder2015/SwiftStudyNote/tree/master/swift-UIImageView
参考文档
UITapGestureRecognizer Class Reference
UIGestureRecognizer Tutorial: Getting Started
How can I cast an NSMutableArray to a Swift array of a specific type?