- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是自动布局的新手,即使这是我的第一次尝试。无论我用它做什么,结果都是白屏。这是我的尝试。
我有一个 UIView
,让我说一个 parentView
框架 (60, 154, 200, 200)
。它是 self.view
的 subview 。
然后我有一个动态 View ,比如 dynamicView
帧 (0, 0, 260, 100)
和一个 label
帧 (15, 25, 230, 50)
是 dynamicView
的 subview 。
当我将 dynamicView
作为 subview 添加到 parentView
时,它超出了 parentView
的范围。因此,我想调整 dynamicView
及其子项(label
)的大小,使其位置位于 parentView
的中心,并且dynamicView
在 parentView
的边界内。
我的第一次尝试是设置 clipsToBounds
,它在 Xcode5、iOS7 中不起作用。所以下一个选择是使用 NSLayoutConstraint
来实现这一点。我对此一无所知。我欢迎你的想法。
最佳答案
我将只解决 dyanmicView 作为 parentView 问题的一部分,然后让你从那里开始
首先:如果您正在动态创建 View ,那么您就可以开始了,但是如果您是从 Storyboard 中创建的,则必须将它从它的父级分离然后重新附加它..这就是你如何摆脱它以前的 NSConstraints(通常是 Storyboard引入的)可能与你的新 NSConstraints 发生冲突。
您还必须将它的 setTranslatesAutoresizingMaskIntoConstraints
设置为 NO b/c 这也会干扰您的 nsconstraints。
我通常会像这样执行最后两个步骤,使用 mapObjectsUsingBlock使创建约束的整个繁琐过程变得更加愉快和自然:
[@[view_1, view_2, /../, view_n] mapObjectsApplyingBlock:^(UIView *view) {
[view removeFromSuperview];
[view setTranslatesAutoresizingMaskIntoConstraints:NO];
[view setHidden:NO];
[superView addSubview:view];
}];
然后在应用 nsconstraints 之前,您必须确保要应用约束的 View 已经附加到它的父 View :
[parentView addSubview:dynamicView];
然后你想创建一个绑定(bind)字典:
NSDictionary *buttonBindingsDictionary = @{ @"parentView" : parentView,
@"dynamicView" : dynamicView};
然后您要使用 visual format language 添加约束.. 我在这里也使用 mapObjectsUsingBlock
(我会用英语解释每个约束):
NSArray *buttonConstraints = [@[@"V:|-[dynamicView(>=200)]-|",
@"|-[dynamicView(>=260)]-|",
] mapObjectsUsingBlock:^id(NSString *formatString, NSUInteger idx){
return [NSLayoutConstraint constraintsWithVisualFormat:formatString options:0 metrics:nil views:buttonBindingsDictionary];
}];
V:|-[dynamicView(>=200)]-|
表示垂直方向.. dynamicView
与其父级之间的上下距离应该相等.. dynamicView 的
高度也应该不小于 200
|-[dynamicView(>=260)]-|
表示水平方向上.. dyanmicview
和它的父级之间的左右距离应该相等..另外dyanmicView的
宽度应该不小于260
注意:您可以自己计算并准确设置 dyanicView
和它的父级之间的左/右/下/上距离。这更简单.. 但有时 nsconstraints 搞砸了,我得自己做。
在那种情况下,它看起来像这样,其中 x
是你想出的距离:
V:|-x-[dynamicView(>=200)]-x-|
|-x-[dynamicView(>=260)]-x-|
然后你必须将约束添加到父 View :
[parentView addConstraints:[buttonConstraints flattenArray]];
注意这里我用了flatten array ,这也是我的库 b/c 中的一种方法,我想将它提供给一个单级数组,而不是数组数组。
然后你就可以开始了!
注意:我知道这可能无法完美地工作.. 但它让您知道要做什么 + 一些帮助文件。这需要一些练习,你应该看看一些 tutorials当然..我建议你从使用 Storyboard的nsconstraints开始(你可以选择一个 View ..然后去编辑器> pin> ..然后选择一些东西..获得一些即时的视觉反馈..你也可以模拟你的观点看起来像什么在 3.5"显示器与 4.0"显示器中通过选择 View Controller 立即在 Storyboard上显示,然后转到属性检查器并在模拟指标下选择不同的尺寸)
慢慢来,但有一件事是肯定的:一旦你进入 nsconstraints,你将永远不会回头!这是完全值得的!
附注你也可以animate View 也使用 nsconstraints.. 以防万一你想知道。
关于iphone - 使用 NSLayoutConstraint 将大型 UIView 居中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19243837/
我正在尝试将 Bootstrap 输入字段置于列 div 的中心,但我尝试过的所有方法似乎都不起作用。 到目前为止我尝试了什么: Enter the inf
这是它的样子: http://i.imgur.com/H0Oqz4Q.png 这是 CSS: #header{ background:url('header.png'); border-radius:
似乎有一个 align 属性工作得非常好,但是可以对齐元素,因此面板上的所有元素都将对齐,以在彼此底部居中,如果它们都小于容器尺寸?类似顶部中心中心的东西。 类似这样的事情: 或者至少水平方向和垂直方
我用 GUI 创建了一个简单的猜谜游戏。问题是,每当我最大化窗口时,整个 GUI 都会卡在顶部中间。我想知道如何将其居中以及如何使其变大。代码如下: import javax.swing.*;
目前我在另一个 View 中有一个 View (它是一个广告),但是因为我使用的是 MATCH_PARENT,所以宽度是整个屏幕的长度,而我只希望它是广告尺寸。现在 WRAP_CONTENT 解决了这
我有一个 UIViewController 子类,它实例化了一个 UIView 子类(我们称之为 viewA)。然后,viewA 有时会实例化另一个 UIView,我们称之为 viewB。 我希望 v
我是 Cocca 和 IOS 开发的新手,发现自己处于以下情况。 我有一张 1024x1024 的背景图片,我想在所有 View 中显示它。我已将以下代码放在应用程序委托(delegate)中的应用程
我正在尝试使用 MathML 作为 HTML5 的一部分来制作居中的盒装数学方程式。问题是盒子。如果我在我的 div 元素上放置一个边框,边框足够高,但它一直延伸到屏幕的左侧和右侧。如果我在我的数学元
我知道这听起来很简单,但它不适合我。我做错了什么? .popuphdr { background-color:#00477f; height:30px; width
我正在为我的网店创建一个新网站 - 我遇到了这个 css 问题...... 系统是在prestashop平台上制作的,但是这是基本的CSS,所以没关系。 在 CMS 页面上,我在将页面居中时遇到问题,
我有一个横跨整个屏幕宽度的按钮: accusantium quia sunt 44% 我希望第一个段落标签中的文本居中,其背景图像紧挨着文本。问题是第一个 居中
http://makememodern.com/portfolio/ 您会看到我在页面上嵌入了一个网站,并且它与页面右侧对齐。我希望它居中。 最佳答案 您将 iframe 的宽度设置为 1100
我的 header 中有一个元素正在从 js 文件中获取数据。 我试图将该元素置于我的页面的中心,但我所做的一切似乎都有效。 我尝试了 margin-left: auto 和 margin-right
这个问题在这里已经有了答案: What does auto do in margin: 0 auto? (8 个答案) 关闭 7 年前。
我试图让这两个按钮并排对齐,在页面的中心垂直和水平。 几个小时以来,我一直在摆弄它,尝试了所有方法,但我无法让它既与页面居中对齐又并排对齐 我希望有人能给我指出正确的方向。谢谢..
我需要将一个 img 居中(带有 class=“key”的那个,但是 float 元素阻止了它。我应该使用什么技术将其居中? 谢谢! GitHub 存储库:https://github.com/Cal
每次我嵌入来自 Google map 的 iframe 时,它都会将标记保留在中间。 即使有工具提示并且只是剪切工具提示数据,它也会这样做: http://jsfiddle.net/V2SVa/
我无法将这些按钮置于页面中央。我只知道我错过了一些愚蠢的东西,但我不知道是什么。这是页面: All Time Last 2 Weeks La
我如何将 div 内的表格 div 对齐到 align=center 最佳答案 asd 关于html - div对齐=居中,我们在Stack Overflow上找到一个类似的问题: htt
有人知道如何在调整浏览器窗口大小时也实现垂直居中吗? 水平效果很好,图像大小调整也很好。我希望图片和链接始终在浏览器中间居中。 另外,为什么 ul 没有像图像那样居中而是向右移动了一点? Here i
我是一名优秀的程序员,十分优秀!