swift UIScrollView简单介绍
2015-11-09 13:48
411 查看
UIScrollView 是用来展示内容超过一个屏幕,需要滑动去看的时候的一个常用控件
首先,我们看如何用Swift创建一个UIScrollView
[objc] view
plaincopy
//创建UIScrollView
let scrollV=UIScrollView(frame: CGRectMake(10, 50, 300, 300))
scrollV.backgroundColor=UIColor.whiteColor()
self.view.addSubview(scrollV)
给ScrollView上添加一个图片看效果
[objc] view
plaincopy
//找一张大图片放到scrollV上
let img=UIImage(named: "test.jpg")
let imageV=UIImageView(image: img)
scrollV.addSubview(imageV)
此时我们发现图片只现实了左上角,而且不能滑动
添加设置
[objc] view
plaincopy
scrollV.contentSize=img!.size
将 scrollV的contentSize 设置为展示内容的大小(此处就是img的大小)
接下来是不是可以滑动
但是,我们发现有个滑动条出现,默认的还不太好看我们试着试着一下
设置滑动条
我们可以 修改滑动条的样式
[objc] view
plaincopy
scrollV.indicatorStyle=UIScrollViewIndicatorStyle.White
样式是一个枚举 大家可以尝试一下其他类型
还可以直接讲滑动条取消
[objc] view
plaincopy
scrollV.showsHorizontalScrollIndicator=false
scrollV.showsVerticalScrollIndicator=false
还有我们发现在滑动到边界的时候发现图片还可以继续滑动,然后反弹回来
其实这个也可以设置
设置反弹效果
[objc] view
plaincopy
scrollV.bounces=false
这样滑动到边界之后就不能再滑动了
图片默认现实的是左上角,我们还可以设置默认图片现实的位置
设置偏移量
[objc] view
plaincopy
scrollV.contentOffset=CGPointMake(100, 100)
这样图片就可以从左边100 上边100 开始显示
接下来我们看几个UiScrollView常用的代理方法
首先,添加协议
设置代理
[objc] view
plaincopy
scrollV.delegate=self
首先,我们看第一个代理方法
[objc] view
plaincopy
func viewForZoomingInScrollView(scrollView: UIScrollView) -> UIView?
scrollView双手滑动缩放的时候调用词方法
我们一首先图片缩放来看下他的用法
当我们双手滑动缩小的时候 我们希望图片缩小,当双手滑动张开的时候 我们希望图片放大
图片最小能缩小到原始的一半 最大能放到到原图的两倍
首先设置图片最大最小倍数
[objc] view
plaincopy
scrollV.minimumZoomScale=0.5
scrollV.maximumZoomScale=2.0
然后实现代理方法
[objc] view
plaincopy
func viewForZoomingInScrollView(scrollView: UIScrollView) -> UIView? {
return scrollView.subviews[0] as? UIView
}
由于 我们scrollView 上只有一个图片所以 subviews取0就是刚才的图片
好了试下效果吧
还有三个代理方法
[objc] view
plaincopy
func scrollViewDidScroll(scrollView: UIScrollView)
滑动scrollView过程中只要图片在动就一直执行
[objc] view
plaincopy
func scrollViewDidEndDragging(scrollView: UIScrollView, willDecelerate decelerate: Bool)
手指拖拽完成离开图片执行此方法
[objc] view
plaincopy
func scrollViewDidEndDecelerating(scrollView: UIScrollView)
图片停止移动还有执行此方法(如果是快速滑动的话手指一开之后图片还会继续滑动一点距离,注意他和手指离开两个代理方法的区别)
我们实现一下代理方法测试一下
[objc] view
plaincopy
func scrollViewDidScroll(scrollView: UIScrollView) {
println("滑动中")
}
func scrollViewDidEndDragging(scrollView: UIScrollView, willDecelerate decelerate: Bool) {
println("停止拖拽")
}
func scrollViewDidEndDecelerating(scrollView: UIScrollView) {
println("停止滑动")
}
首先,我们看如何用Swift创建一个UIScrollView
[objc] view
plaincopy
//创建UIScrollView
let scrollV=UIScrollView(frame: CGRectMake(10, 50, 300, 300))
scrollV.backgroundColor=UIColor.whiteColor()
self.view.addSubview(scrollV)
给ScrollView上添加一个图片看效果
[objc] view
plaincopy
//找一张大图片放到scrollV上
let img=UIImage(named: "test.jpg")
let imageV=UIImageView(image: img)
scrollV.addSubview(imageV)
此时我们发现图片只现实了左上角,而且不能滑动
添加设置
[objc] view
plaincopy
scrollV.contentSize=img!.size
将 scrollV的contentSize 设置为展示内容的大小(此处就是img的大小)
接下来是不是可以滑动
但是,我们发现有个滑动条出现,默认的还不太好看我们试着试着一下
设置滑动条
我们可以 修改滑动条的样式
[objc] view
plaincopy
scrollV.indicatorStyle=UIScrollViewIndicatorStyle.White
样式是一个枚举 大家可以尝试一下其他类型
还可以直接讲滑动条取消
[objc] view
plaincopy
scrollV.showsHorizontalScrollIndicator=false
scrollV.showsVerticalScrollIndicator=false
还有我们发现在滑动到边界的时候发现图片还可以继续滑动,然后反弹回来
其实这个也可以设置
设置反弹效果
[objc] view
plaincopy
scrollV.bounces=false
这样滑动到边界之后就不能再滑动了
图片默认现实的是左上角,我们还可以设置默认图片现实的位置
设置偏移量
[objc] view
plaincopy
scrollV.contentOffset=CGPointMake(100, 100)
这样图片就可以从左边100 上边100 开始显示
接下来我们看几个UiScrollView常用的代理方法
首先,添加协议
设置代理
[objc] view
plaincopy
scrollV.delegate=self
首先,我们看第一个代理方法
[objc] view
plaincopy
func viewForZoomingInScrollView(scrollView: UIScrollView) -> UIView?
scrollView双手滑动缩放的时候调用词方法
我们一首先图片缩放来看下他的用法
当我们双手滑动缩小的时候 我们希望图片缩小,当双手滑动张开的时候 我们希望图片放大
图片最小能缩小到原始的一半 最大能放到到原图的两倍
首先设置图片最大最小倍数
[objc] view
plaincopy
scrollV.minimumZoomScale=0.5
scrollV.maximumZoomScale=2.0
然后实现代理方法
[objc] view
plaincopy
func viewForZoomingInScrollView(scrollView: UIScrollView) -> UIView? {
return scrollView.subviews[0] as? UIView
}
由于 我们scrollView 上只有一个图片所以 subviews取0就是刚才的图片
好了试下效果吧
还有三个代理方法
[objc] view
plaincopy
func scrollViewDidScroll(scrollView: UIScrollView)
滑动scrollView过程中只要图片在动就一直执行
[objc] view
plaincopy
func scrollViewDidEndDragging(scrollView: UIScrollView, willDecelerate decelerate: Bool)
手指拖拽完成离开图片执行此方法
[objc] view
plaincopy
func scrollViewDidEndDecelerating(scrollView: UIScrollView)
图片停止移动还有执行此方法(如果是快速滑动的话手指一开之后图片还会继续滑动一点距离,注意他和手指离开两个代理方法的区别)
我们实现一下代理方法测试一下
[objc] view
plaincopy
func scrollViewDidScroll(scrollView: UIScrollView) {
println("滑动中")
}
func scrollViewDidEndDragging(scrollView: UIScrollView, willDecelerate decelerate: Bool) {
println("停止拖拽")
}
func scrollViewDidEndDecelerating(scrollView: UIScrollView) {
println("停止滑动")
}
相关文章推荐
- swift UIScrollView简单介绍
- swift UITabBarController标签栏控制器
- swift UITabBarController标签栏控制器
- swift 设置 navigation左右两侧按钮
- swift 设置 navigation左右两侧按钮
- swift UINavigationController属性设置
- swift UINavigationController属性设置
- swift uinavigationController 视图控制器切换(二)
- swift uinavigationController 视图控制器切换(二)
- Swift UINavigationController(导航控制器)的创建及导航栏的设置
- Swift UINavigationController(导航控制器)的创建及导航栏的设置
- swift UIViewController生命周期
- swift UIViewController生命周期
- swift UITextFiled边框设置
- swift UITextFiled边框设置
- swift UIImageView 子view接受点击
- swift UIImageView 子view接受点击
- swift UIImageView简单动画
- swift UIImageView简单动画
- swift UIImageView构造方法