因此,在阅读了Apple网站上的技术说明并阅读了有关使用Autolayout的UIScrollview的iOS 11编程的matt neuburg的书之后,我无法完全理解这一切的概念.

基本上我想要的是一个Scrollview,它有一个子视图ChildView,其中这个子视图有一个Textview.

下面我附上了我试图以编程方式实现的无模型,没有故事板的模型.

至于代码,这就是我通常提出的:

let Scroller: UIScrollView = {
    let scroll = UIScrollView()
    scroll.translatesAutoresizingMaskIntoConstraints = false
    scroll.backgroundColor = UIColor.alizarinColor()
    return scroll
}()

// Content view

let ContentView : UIView = {

    let content = UIView()
    content.translatesAutoresizingMaskIntoConstraints = false
    content.backgroundColor = UIColor.blue
    return content
}()

 override func viewDidLoad() {


    super.viewDidLoad()

   self.view.addSubview(Scroller)


    // Auto layout
    Scroller.leftAnchor.constraint(equalTo: view.leftAnchor,constant:0).isActive = true
    Scroller.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor,constant: 0).isActive = true
    Scroller.rightAnchor.constraint(equalTo: view.rightAnchor,constant: 0).isActive = true
    Scroller.bottomAnchor.constraint(equalTo: view.safeAreaLayoutGuide.bottomAnchor,constant: 0).isActive = true




    Scroller.addSubview(ContentView)
    // Undefined Content view 

   }

请注意:对于ContentView,我通常定义约束来锚定滚动视图内的边缘,但在这种情况下不支持Autolayout,以及我希望它在键盘变为FirstFirstResponder时垂直向上滚动的事实.我想到这个尝试工作的另一种方法是创建一个比Scrollview更大的UIView,以允许子视图成为这个以滚动视图为父视图的大视图的子视图.

我的问题:我怎样才能从这里开始实现这个目标?有什么建议?
我一直在考虑这样的事情:( ContentView将是允许其可滚动的较大视图,并且子视图将是hiarchy中的第3个子视图)

解决方法

我仔细阅读了关于UIScrollView的Apple文档,特别是它如何与自动布局一起使用,我也更喜欢程序化路径.首先,您不需要创建一个虚假的内容视图,您可以直接将子视图添加到滚动视图(我更喜欢这个,因为我认为一个虚假的视图是一个无关的对象). Apple,AFAIK,不建议创建一个,但仅建议您可以.而且,据我记忆,他们已经制作了他们没有的例子.其次,滚动视图中的子视图不应该(可能不能)依赖滚动视图来确定它们的宽度或高度.第三,您的约束必须从左到右和从上到下链接到自动布局,以便为您创建内容视图.第三个“规则”可能有点令人困惑甚至看起来违反直觉,但这正是Apple希望您构建滚动视图的方式.

具体来说,当您创建滚动视图时,您可以为其框架指定控制器视图的边界:

scrollView.translatesAutoresizingMaskIntoConstraints = false
view.addSubview(scrollView)
scrollView.leadingAnchor.constraint(equalTo: view.leadingAnchor).isActive = true
scrollView.topAnchor.constraint(equalTo: view.topAnchor).isActive = true
scrollView.widthAnchor.constraint(equalTo: view.widthAnchor).isActive = true
scrollView.heightAnchor.constraint(equalTo: view.heightAnchor).isActive = true

然后,您必须通过将其子视图锚定到滚动视图的边缘来设置内容视图的边界.因此,您的最顶层视图必须锚定在滚动视图的顶部,其宽度不能超过滚动视图的宽度(这是视图的宽度)(如果您的目标是仅垂直滚动).

topMostView.translatesAutoresizingMaskIntoConstraints = false
scrollView.addSubview(topMostView)
topMostView.leadingAnchor.constraint(equalTo: scrollView.leadingAnchor).isActive = true
topMostView.topAnchor.constraint(equalTo: scrollView.topAnchor).isActive = true
topMostView.widthAnchor.constraint(equalTo: view.widthAnchor).isActive = true
topMostView.heightAnchor.constraint(equalToConstant: 1000).isActive = true

请注意,topMostView不依赖滚动视图来确定其大小(仅限其位置).

滚动视图中的内容现在的高度为1000,但它不会滚动,因为没有任何内容锚定在滚动视图的底部.因此,请在最底层的视图中执行此操作.

bottomMostView.translatesAutoresizingMaskIntoConstraints = false
scrollView.addSubview(bottomMostView)
bottomMostView.leadingAnchor.constraint(equalTo: scrollView.leadingAnchor).isActive = true
bottomMostView.topAnchor.constraint(equalTo: topMostView.bottomAnchor).isActive = true
bottomMostView.widthAnchor.constraint(equalTo: view.widthAnchor).isActive = true
bottomMostView.heightAnchor.constraint(equalToConstant: 1000).isActive = true

bottomMostView.bottomAnchor.constraint(equalTo: scrollView.bottomAnchor).isActive = true

最后一个锚似乎违反直觉,因为你将一个1000点高的视图锚定到一个锚点,你刚刚锚定到视图的底部,它肯定低于1000点高.但这就是Apple希望你这样做的方式.使用这种方法,您不仅不需要创建内容视图,实际上您可以假装它不存在 – 当然,除非您需要它仍然可以从滚动视图的属性中读取的边界.

实际上,这个原则超越了滚动视图.当您使用自动布局创建自定义UITableViewCell时,将从左到右和从上到下的约束链接到最顶部子视图锚定到单元格顶部的位置(topMostView.topAnchor.constraint(equalTo:self.topAnchor) ).isActive = true)和单元格底部的最底部子视图(bottomMostView.topAnchor.constraint(equalTo:self.bottomAnchor).isActive = true)并且您有自定义单元格.

ios – 使用Autolayout编程的UIScrollview的更多相关文章

  1. ios – 删除中间视图时Autolayout会折叠空间

    关于如何正确定义在删除给定视图时会折叠视图之间的空间的约束,我感到有点难过.我尝试添加大于或等于关系的垂直约束,但是,似乎不满足约束的最小距离.例如,给定以下具有三个约束V的布局:[A]-5-[B],V:[B]-5-[C],并且V:[A]–(>=5)–[C]:删除视图B后,我希望它看起来像这样:但它看起来像这样:解决方法如果您正在寻找可扩展的,那么您可能不得不在代码中执行此操作.我喜欢用的东西这将

  2. ios – UITextField中的Autolayout:执行-layoutSubviews后仍需要自动布局

    我究竟做错了什么?

  3. ios – UIScrollView内容不允许用户交互

    我有一个启用了分页的UIScrollView,如下所示:在UIScrollView中,我添加了几个UIWebViews,并将其启用的交互设置为是这样的.它打破了UIScrollView上的分页和所有触摸.如果我将用户交互设置为NO,则页面有效,但我无法在UIWebView中突出显示文本.我试着像下面那样对UIScrollView进行子类化,但是会出现同样的情况.任何的想法?

  4. ios – UIScrollView中的UIControll未接收到触摸事件

    我在我的项目中使用SevenSwitch.我需要将它添加到UIScrollView中,但是当我将它添加到滚动视图中时,控件似乎无法接收触摸事件.我尝试了子类滚动视图并覆盖下面的代码:还补充说:但仍然无法接收触摸事件.如何阻止scrollview阻止UIControl接收触摸?

  5. ios – UIScrollView的平滑自定义分页

    我在UIScrollView中有两个(可能更多)视图,并希望使用分页.当我尝试使用UIScrollView的默认分页选项时出现问题,因为视图具有不同的宽度,无法正确分页.所以我已经实现了一个有效的自定义分页代码.但是,当滚动较慢时,它不会按预期运行.(它回到没有动画的原始位置.)以下是我目前通过uiscrollviewdelegate进行自定义分页的方法我想要的是:是)我有的:解决方法尝试下面的自

  6. ios – 如何将UIScrollView的背景图像设置为可伸缩图像?

    我想将UIScrollView的背景图像设置为可伸缩的图像.我试过了:但它并没有伸展.我能做什么?解决方法如果要利用UIImage的可调整大小的属性,则需要使用UIImageView.正如您所注意到的,如果将其设置为背景颜色则不起作用.只需创建一个UIImageView并将其放在UIScrollView后面,如果必须修复它,或者在UIScrollView中放入与contentSize相同的大小,如果你想要滚动它…

  7. ios – 使用autolayout为包含子视图的视图设置动画

    我已经尝试了一切:添加和删除约束而不是修改常量值,在InterfaceBuilder上为子视图添加约束…

  8. ios – 取消选中“调整滚动视图插入”xcode 6后UIScrollView不滚动

    谢谢.解决方法我解决顶部标签和导航栏之间额外填充的方法是在“扩展边缘”部分中取消选中属性检查器中的“顶部条形图”.取消选中后,故事板上的项目可能会移动.不要重新安排它们.运行模拟器,它应该工作.注意:选中“调整滚动视图插入”,否则不滚动任何内容.我的属性:

  9. ios – 滚动指示器在UIScrollView禁用弹跳时被卡住

    难道我做错了什么?如果这是一个错误,那么有没有人知道解决方法或修复?解决方法您是否为滚动视图添加了点击手势,如果没有,请尝试添加它?

  10. ios – 使用双指平移和缩放分页UIScrollView

    *编辑:实际上,在这种情况下它不会滚动.只需轻轻一按,视图就不再顺畅滑动……

随机推荐

  1. iOS实现拖拽View跟随手指浮动效果

    这篇文章主要为大家详细介绍了iOS实现拖拽View跟随手指浮动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  2. iOS – genstrings:无法连接到输出目录en.lproj

    使用我桌面上的项目文件夹,我启动终端输入:cd然后将我的项目文件夹拖到终端,它给了我路径.然后我将这行代码粘贴到终端中找.-name*.m|xargsgenstrings-oen.lproj我在终端中收到此错误消息:genstrings:无法连接到输出目录en.lproj它多次打印这行,然后说我的项目是一个目录的路径?没有.strings文件.对我做错了什么的想法?

  3. iOS 7 UIButtonBarItem图像没有色调

    如何确保按钮图标采用全局色调?解决方法只是想将其转换为根注释,以便为“回答”复选标记提供更好的上下文,并提供更好的格式.我能想出这个!

  4. ios – 在自定义相机层的AVFoundation中自动对焦和自动曝光

    为AVFoundation定制图层相机创建精确的自动对焦和曝光的最佳方法是什么?

  5. ios – Xcode找不到Alamofire,错误:没有这样的模块’Alamofire’

    我正在尝试按照github(https://github.com/Alamofire/Alamofire#cocoapods)指令将Alamofire包含在我的Swift项目中.我创建了一个新项目,导航到项目目录并运行此命令sudogeminstallcocoapods.然后我面临以下错误:搜索后我设法通过运行此命令安装cocoapodssudogeminstall-n/usr/local/bin

  6. ios – 在没有iPhone6s或更新的情况下测试ARKit

    我在决定下载Xcode9之前.我想玩新的框架–ARKit.我知道要用ARKit运行app我需要一个带有A9芯片或更新版本的设备.不幸的是我有一个较旧的.我的问题是已经下载了新Xcode的人.在我的情况下有可能运行ARKit应用程序吗?那个或其他任何模拟器?任何想法或我将不得不购买新设备?解决方法任何iOS11设备都可以使用ARKit,但是具有高质量AR体验的全球跟踪功能需要使用A9或更高版本处理器的设备.使用iOS11测试版更新您的设备是必要的.

  7. 将iOS应用移植到Android

    我们制作了一个具有2000个目标c类的退出大型iOS应用程序.我想知道有一个最佳实践指南将其移植到Android?此外,由于我们的应用程序大量使用UINavigation和UIView控制器,我想知道在Android上有类似的模型和实现.谢谢到目前为止,guenter解决方法老实说,我认为你正在计划的只是制作难以维护的糟糕代码.我意识到这听起来像很多工作,但从长远来看它会更容易,我只是将应用程序的概念“移植”到android并从头开始编写.

  8. ios – 在Swift中覆盖Objective C类方法

    我是Swift的初学者,我正在尝试在Swift项目中使用JSONModel.我想从JSONModel覆盖方法keyMapper,但我没有找到如何覆盖模型类中的Objective-C类方法.该方法的签名是:我怎样才能做到这一点?解决方法您可以像覆盖实例方法一样执行此操作,但使用class关键字除外:

  9. ios – 在WKWebView中获取链接URL

    我想在WKWebView中获取tapped链接的url.链接采用自定义格式,可触发应用中的某些操作.例如HTTP://我的网站/帮助#深层链接对讲.我这样使用KVO:这在第一次点击链接时效果很好.但是,如果我连续两次点击相同的链接,它将不报告链接点击.是否有解决方法来解决这个问题,以便我可以检测每个点击并获取链接?任何关于这个的指针都会很棒!解决方法像这样更改addobserver在observeValue函数中,您可以获得两个值

  10. ios – 在Swift的UIView中找到UILabel

    我正在尝试在我的UIViewControllers的超级视图中找到我的UILabels.这是我的代码:这是在Objective-C中推荐的方式,但是在Swift中我只得到UIViews和CALayer.我肯定在提供给这个方法的视图中有UILabel.我错过了什么?我的UIViewController中的调用:解决方法使用函数式编程概念可以更轻松地实现这一目标.

返回
顶部