- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我在我的项目中使用了自动布局,并且我有一个 ScrollView ,其中有一个按钮居中。我已经让 ScrollView 滚动,但没有占据整个屏幕。
我已尝试按照此处的教程进行操作:https://developer.apple.com/library/ios/technotes/tn2154/_index.html ,以及我在这里检查了一些类似的问题。问题是我希望 ScrollView 的内容居中,而不是固定在顶部/底部/左侧/右侧。
这是我的 View 层次结构:
你能帮帮我吗?
最佳答案
您在 ScrollView 和它的 super View 之间添加了约束。这些约束决定了 ScrollView 的框架。你可以把 ScrollView 想象成一个窗口,通过它你可以看到后面的内容。框架只是窗口的大小。当然,你也可以滑动窗口,让你看到部分内容。
现在您有了窗口的大小,但您还需要告诉 Xcode 内容的大小。如果你只是说把所有东西都放在中间而不告诉宽度,Xcode 怎么知道中间在哪里?
所以,你必须告诉宽度(以及高度)。让我们考虑一个简单的例子,如何在 ScrollView 中将单个标签居中。
您应该首先将 ScrollView 的边缘固定到其父 View ,就像您所做的那样。之后你应该在标签的边缘和 ScrollView 的边缘之间添加约束,此外,你还应该添加标签的with和高度约束。
前导空格、尾随空格和宽度一起给出了内容的宽度,而顶部空格、底部空格和高度一起给出了内容的高度。
|---前导空格---|标签宽度|---尾随空格---|
|------------ ScrollView 的内容------------|
但是您可能希望将内容 View 的 with 设置为与屏幕的 with 相等,那么您需要进行一些编程。在您的代码中设置 socket 属性
@property (weak, nonatomic) IBOutlet NSLayoutConstraint *trailingSpace;
@property (weak, nonatomic) IBOutlet NSLayoutConstraint *leadingSpace;
@property (weak, nonatomic) IBOutlet NSLayoutConstraint *width;
在您的 viewWillLayoutSubviews
中执行此操作
CGFloat contentWidth = self.view.frame.size.width;
CGFloat horiPadding = (contentWidth - self.width.constant) / 2;
_trailingSpace.constant = horiPadding;
_leadingSpace.constant = horiPadding;
现在标签位于 ScrollView 的水平中心!你的 ScrollView 已经知道它的内容,所以你不需要为你在 ScrollView 中添加的任何其他 View 执行此操作:你可以只添加中心约束。
你也可以对高度做同样的事情。
关于ios - 使用自动布局时 UIScrollview 的中心内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25021745/
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: How to align a to the middle of the page 这是一个简单的问题,应该有一个简
我想知道如何在屏幕中央的ListView中生成2个itens。 class _CategoriesState extends State { List categories = ["Anterio
我需要修复 UICollectionView 的一个小问题,当在 6s 设备尺寸上时,我得到如下布局: 但是,我想知道将它们居中以使其成为两条线的最佳方法是什么,或者我应该将它们缩小一点以便可以放置其
我尝试在 UIImageView 中居中 CAShapeLayer 但没有成功,我找到了解决方案,将其(CAShapeLayer)添加到 UIVIew,然后将 UIVIew 添加到 ImageView
一直在从线性布局和相对布局切换,因为我想实现图像的居中。 显示图片:
* { margin:0; padding:0; } /** General Style Info **/ body { background: #003d4c; co
我目前正在尝试修改我在 Wordpress 上的 Royal Slider 插件 (http://dimsemenov.com/plugins/royal-slider/) 我的目标是将所有标题的文本
我已经坚持了一段时间,因此简化了我的要求。当您单击标记时,信息窗口将打开,当用户缩放时,我希望该标记位于 map 的中心。这不起作用,但我认为它很接近: function bindInfoWindow
/* Linked Styles */ body { padding: 0 !important;
这个问题在这里已经有了答案: How do I center floated elements? (12 个答案) 关闭 7 年前。
这个问题在这里已经有了答案: Is there an equivalent to background-size: cover and contain for image elements? (1
我试图让我的页眉停留在页面的中间,不管我在什么窗口大小。 我试过使用 Bootstrap。 StackOverflow 还有这个 CSS。 .section-t
我有一个 1600 像素宽的页面。主要区域虽然只有 900 像素宽。我有一个导航应该固定在页面的中心(它是)。我的问题是当我打开页面时,页面固定在左侧而不是在打开时居中。当用户访问该网站时,我需要做什
我正在尝试找到 View 的中心。对于非旋转 View ,该值是正确的,但对于旋转 View ,它不正确,因为中心 (0,0) 正在旋转。在缩放的情况下,即使缩放后宽度和高度也保持不变 我正在使用以下
预期效果是将 Kartennummer 和 Passwort 集中。 这怎么可能? 我为此使用了一个自定义类: import 'package:flutter/material.dart'; impo
我管理着许多 Maven 项目。他们中的大多数部署到我们的内部 maven 存储库。现在我想开始向 Maven Central 发布一个项目。到目前为止,我有一个父 POM,它指定了我们内部存储库的
我试图锚定两个进展,但我看不到获得预期结果的方法。 我希望左边的进度条固定在左边,右边的条固定在中心固定(如下图所示) (下图显示调整大小的表格) 我尝试将控件放在具有各种 anchor 的停靠面板上
我正在玩 Angular 模态 ui 对话框。我想知道有什么方法可以让它居中?我发现了一个类似的问题: Twitter Bootstrap - Center Modal Dialog 但无法使其工作,
是否可以将值标签放置在条形上,使它们位于条形的中心? 如果我设置条形 align: "center",则条形上的标签将关闭且不居中。 $(function() { var d
http://www.asp.net/signalr/overview/signalr-20/getting-started-with-signalr-20/tutorial-signalr-20-s
我是一名优秀的程序员,十分优秀!