转自:http://www.hangge.com/blog/cache/detail_543.html
1,当图片尺寸超过屏幕时,使用UIScrollView可以实现滚动条视图,即手指触摸滚动屏幕方便浏览整个页面。
var
scrollView=
UIScrollView
()
scrollView.frame=
self
.view.bounds
imageView=
UIImageView
(image:
UIImage
(named:
"bigpic"
))
scrollView.contentSize=imageView.bounds.size;
scrollView.addSubview(imageView);
.view.addSubview(scrollView)
2,获取滚动视图移动的x,y坐标
通过scrollView.contentOffset.x与scrollView.contentOffset.y我们可以取到移动的偏移位置
import
UIKit
scrollView:
!
override
func
viewDidLoad() {
super
.viewDidLoad()
scrollView=
UIScrollView
()
//设置代理
scrollView.delegate =
self
.view.bounds
"ii"
))
scrollView.contentSize=imageView.bounds.size;
scrollView.addSubview(imageView);
.view.addSubview(scrollView)
}
//视图滚动中一直触发
scrollViewDidScroll(scrollView:
) {
println
(
"x:\(scrollView.contentOffset.x) y:\(scrollView.contentOffset.y)"
)
}
didReceiveMemoryWarning() {
.didReceiveMemoryWarning()
}
}
3,手势放大缩小
要实现放大缩小功能,需要指定UIScrollView的允许缩放最大比例和最小比例(默认都是是1.0)。
同时delegate属性指定一个委托类,委托类要继承uiscrollviewdelegate协议,并在委托类中实现viewForZoomingInScrollView方法。
(注:在模拟器中测试,需要按住option键再拖动内容)
scrollView.minimumZoomScale=0.1
//最小比例
scrollView.maximumZoomScale=3
//最大比例
scrollView.delegate=
self
viewForZoomingInScrollView( scrollView:
!) ->
UIView
!{
for
subview :
AnyObject
in
scrollView.subviews {
if
subview.isKindOfClass(
) {
return
subview
as
UIView
}
}
return
nil
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。