【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记30 ScrollView Demo实战
在上一话中我们创建了一个通过URL读取图片的Demo,这个Demo是不能拖动和缩放的。如今给它添加选项让它能够手动切换URL,并把图片加入到ScrollView中。
向Storyboard中拖入一个splitviewController。把ImageViewController作为detail视图,把project中自带的那个viewcontroller作为rootview,如今storyboard中的场景如图:
如今执行一下:
点击back能够切换到主界面,眼下这个界面是空的。我们须要向当中添加一些功能button。添加三个button分别获取模型中的三张图片,而且调整自己主动布局:
然后我们须要做的是建立过渡。
按住control键拖动button到ImageViewController,选择show detail segue,分别命名为fengjing1、fengjing2、fengjing3。在viewController中设置过渡方法:
import UIKit
class ViewController: UIViewController {
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?
) {
if let ivc = segue.destinationViewController as?
ImageViewController,let identifier = segue.identifier{
switch identifier{
case "fengjing1":
ivc.imageURL = DemoURL.Fengjing.fengjing1
ivc.title = "风景1"
case "fengjing2":
ivc.imageURL = DemoURL.Fengjing.fengjing2
ivc.title = "风景2"
case "fengjing3":
ivc.imageURL = DemoURL.Fengjing.fengjing3
ivc.title = "风景3"
default:break
}
}
}
}
如今来执行试试,你会发现点击全部button依旧仅仅显示默认的图片,这是怎么回事呢?
这是由于我们之前在viewDiaLoad中添加了測试代码。如今把測试代码删掉。
再次执行你会看到初始化打开的页面上没有照片,返回到主页面点击button选择照片,由于图片非常大,button会卡顿,在图片载入完毕后才会跳转到照片的显示页面。
在如今ImageViewController中拖拽一个scrollview,点击约束中的reset to suggested Constraints。
然后把图片放到这个滚动视图中,在代码中生成滚动视图的outlet。
首先要改动的地方是viewDidLoad方法,imageView不再放到view中而是放到scrollview中:
override func viewDidLoad() {
super.viewDidLoad()
scrollview.addSubview(imageView)
}
其次不论什么图片发生变化的地方都须要改动scrollview的尺寸,由于我们须要scrollview一直保持和它上面的imageview同样的尺寸:
outlet中:
@IBOutlet weak var scrollview: UIScrollView!{
didSet{
scrollview.contentSize = imageView.frame.size
}
}
计算属性image的定义中:
private var image:UIImage? {
get {return imageView.image}
set {
imageView.image = newValue
imageView.sizeToFit()
scrollview?.contentSize = imageView.frame.size
}
}
这里在scrollview尾部添加?是由于在图片变动时不能保证scrollview存在,而oulet和viewDidLoad方法中使用scrollview不用加?是由于在两种情况中scrollview是肯定存在的,这也是保护程序不异常退出的有效方法。如今来执行一下试试,点击button时依然非常慢。可喜可贺的是我们能够拖动图像了。
显然如今我们须要加入缩放方法,加入缩放的最好位置是在scrollview的outlet中。记得我们之前讲过的使用方法首先让ImageViewController遵守scrollview的代理,然后改动例如以下outlet:
@IBOutlet weak var scrollview: UIScrollView!{
didSet{
scrollview.delegate = self
scrollview.maximumZoomScale = 1.0
scrollview.minimumZoomScale = 0.05
scrollview.contentSize = imageView.frame.size
}
}
由于scrollview的代理方法是OC风格的,所以即便你没有实现代理方法,也不会报错,如今我们实现须要的代理方法.
选择须要进行缩放的视图,显然是我们的imageView
func viewForZoomingInScrollView(scrollView: UIScrollView) -> UIView? {
return imageView
}
如今执行,然后按住option键能够模拟两个手指的缩放操作,效果例如以下:
【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记30 ScrollView Demo实战的更多相关文章
- 【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记19 为Demo添加手势
在这一话中我们将应用上一话学到的知识来为Demo添加手势识别,首先添加一个缩放的功能,其次添加一个拖动功能,使得小人的表情可以随着我们的手指改变. 首先来添加一个缩放手势的识别器,我们来到FaceVi ...
- 【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记1 IOS8概述
首先感谢网易公开课和SwiftV课堂的朋友们辛苦翻译,这个系列是我学习斯坦福IOS8公开课的个人心得体会和笔记,希望能给大家带来启发. 首先我们要知道IOS系统中的结构情况,从贴近硬件的底层到贴近用户 ...
- 【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记2 Xcode、Auto Layout及MVC
原文链接不知道在哪, 接着上一话来讲,上一话中讲到了MVC,那么MVC在IOS8开发中是如何应用的呢?Paul Hegarty老师给我们展示了一个计算器的Demo,首先新建一个工程,老师把AppDel ...
- 【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记3 Xcode、Auto Layout及MVC
继续上一话中的计算器Demo.上一话讲到类必须被初始化.类中的属性也必须被初始化,所以你不能仅仅声明而不给它一个处置,那么问题来了,我们从storyboard中拖拽的@IBOutlet为什么仅仅有声明 ...
- 【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记38 Unwind Segue反向过渡
之前我们接触过了segue,这是IOS中最主要的传递方式,今天来解说一下怎样进行反向的segue. 反向过渡的使用前提是发出过渡的MVC必须是由目标MVC直接或者间接正向过渡来的.反向过渡是唯一不会创 ...
- 【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记35 UITextField文本框
本话来介绍UIKit框架中的组件UITextField. UItextField(文本框)和Label看起来看像,可是文本框是能够编辑的.在UI中使用文本框要注意.由于在模拟器上面输入文字是能够使用电 ...
- 斯坦福iOS7公开课11笔记及演示Demo&访问HTTPS链接下载数据
这一节主要介绍UITableView以及iPad,Demo为从Flicker下载图片并显示,但是实际过程中发现需要FQ并使用HTTPS连接,所以这次用了两个Demo,一个是课程中的Demo,另一个是简 ...
- 斯坦福iOS7公开课10笔记及演示Demo
这一节主要介绍了多线程中的串行队列以及滚动视图UIScrollView. 1 .多线程 这一节只是简单介绍了多线程的串行队列,即把任务加入线程队列后按顺序逐步执行. (1)目前iOS多线程提供的方法主 ...
- 斯坦福iOS7公开课7-9笔记及演示Demo
这一部分主要介绍了iOS的绘图.手势.协议.block.力学特效动画(包括重力.碰撞.吸附等)以及自动布局的内容. 1.绘图.手势 (1)调用一个自定义的UIView时,可以使用awakeFromNi ...
随机推荐
- mysql服务性能优化—my.cnf_my.ini配置说明详解(16G内存)
这配置已经优化的不错了,如果你的mysql没有什么特殊情况的话,可以直接使用该配置参数 MYSQL服务器my.cnf配置文档详解硬件:内存16G [client]port = 3306socket = ...
- 疫情控制(NOIP2012)庆祝2012满贯!٩(๑•◡-๑)۶ⒽⓤⒼ
丧病至极的D2T3啊! 好吧~ 先放个传送门~ 原题传送门 好吧,这道题呢.. 根据题意我们可以很明显的看出来 军队往上走的越多(在没到根节点之前),效益一定越大.. 所以可以分情况讨论: 对于无法走 ...
- Sqlite插入、修改、删除表里面的数据
转载 2014年05月10日 10:38:21 标签: sqlite3 / 数据库 8688 转自:http://www.cnblogs.com/myqiao/archive/2011/07/13/2 ...
- Linux C/C++内存泄漏检测工具:Valgrind
Valgrind 是一款 Linux下(支持 x86.x86_64和ppc32)程序的内存调试工具,它可以对编译后的二进制程序进行内存使用监测(C语言中的malloc和free,以及C++中的new和 ...
- 阿里云服务器上使用apt-get install出现404 Not Found
阿里云服务器上使用apt-get install出现404 Not Found 刚申请了的阿里云服务器,在其Ubuntu上用apt-get install安装软件时,会遇到 Failed to fet ...
- OutputDebugString方便格式化WIN32封装
void TRACE(LPCTSTR lpszFmt, ...) { va_list args; va_start(args, lpszFmt); ; TCHAR *lpszBuf = (TCHAR* ...
- Appium+python自动化18-brew、carthage和appium-doctor【转载】
前言 本篇安装brew.carthage,解决启动appium时的报错问题,另外安装appium-doctor检查appium的环境 1.brew 2.carthage 3.appium-doctor ...
- [loj#101] 最大流 网络流模板
#101. 最大流 内存限制:512 MiB时间限制:5000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据 题目描述 这是一道模板题. 给定 ...
- Netty源码学习(六)ChannelPipeline
0. ChannelPipeline简介 ChannelPipeline = Channel + Pipeline,也就是说首先它与Channel绑定,然后它是起到类似于管道的作用:字节流在Chann ...
- Codeforces 1029 E. Tree with Small Distances(树上dp)
题目直通车:http://codeforces.com/problemset/problem/1029/E 思路大意:在树上做dp,依次更新ar数组,ar[i]表示以i为根节点的子树对答案的最小贡献值 ...