菜鸟教程小白 发表于 2022-12-11 19:37:26

ios - 如何修复官方 iOS 应用开发教程中的 Auto Layout 问题?


                                            <p><p>在 <a href="https://developer.apple.com/library/content/referencelibrary/GettingStarted/DevelopiOSAppsSwift/ImplementEditAndDeleteBehavior.html#//apple_ref/doc/uid/TP40015214-CH9-SW1" rel="noreferrer noopener nofollow">Implement Edit and Delete Behavior</a> 结束时在官方 iOS 应用程序开发教程部分,提到布局有错误,使用堆栈 View 修复这些错误留给读者练习。
为了修复它们,我遵循了以下步骤:</p>

<ol>
<li>添加一个水平堆栈 View ,其中将包含 UIImageView 和一个垂直堆栈 View 。</li>
<li>将水平堆栈 View 的边缘约束到父 View 的边缘。</li>
<li>将标签和评级控制添加到垂直堆栈 View 。</li>
<li>在 UIImageView 中将内容模式设置为 Aspect Fit。</li>
<li>将 UIImageView 的 CHCR 属性设置为全 1000。</li>
</ol>

<p> <a href="/image/Zdp4E.png" rel="noreferrer noopener nofollow"><img src="/image/Zdp4E.png" alt="Your Meals Scene"/></a> </p>

<p>但是,布局仍然不是我喜欢的。例如,我在 iPhone 5 模拟器中启动了应用程序,情况如下:</p>

<p> <a href="/image/BdrTz.png" rel="noreferrer noopener nofollow"><img src="/image/BdrTz.png" alt="Your Meals Scene on iPhone 5"/></a> </p>

<p> ImageView 不会扩展到单元格顶部和底部(保持纵横比)。此外,当我点击“编辑”时, ImageView 会缩小而不是评级控制和标签:</p>

<p> <a href="/image/gmLta.png" rel="noreferrer noopener nofollow"><img src="/image/gmLta.png" alt="enter image description here"/></a> </p>

<p>类似地,当我们向左滑动一行时,不是将 label 和 Rating Control 缩小,而是将 ImageView 滑出 View :</p>

<p> <a href="/image/ww2yI.png" rel="noreferrer noopener nofollow"><img src="/image/ww2yI.png" alt="enter image description here"/></a> </p>

<p>我希望 ImageView 完全保留在那里,并根据需要缩小评级控制和标签。</p>

<p>我还尝试将 Rating Control 替换为包含 5 个普通按钮的普通水平堆栈 View 。结果如下:</p>

<p> <a href="/image/fmhIu.png" rel="noreferrer noopener nofollow"><img src="/image/fmhIu.png" alt="enter image description here"/></a> </p>

<p> <a href="/image/C9E5d.png" rel="noreferrer noopener nofollow"><img src="/image/C9E5d.png" alt="enter image description here"/></a> </p>

<p> <a href="/image/lAWj7.png" rel="noreferrer noopener nofollow"><img src="/image/lAWj7.png" alt="enter image description here"/></a> </p>

<p> <a href="/image/DjUem.png" rel="noreferrer noopener nofollow"><img src="/image/DjUem.png" alt="enter image description here"/></a> </p>

<p>这一次,UIImageView 覆盖了整个单元格。我已经预料到了:</p>

<ol>
<li>UIImageView 的高度等于单元格的高度。</li>
<li>UIImageView 的宽度与高度成正比(因为我在 Interface Builder 中将 UIImageView 的 Content Mode 设置为 Aspect Fit)。</li>
<li>标签和新评级控制要覆盖的剩余空间。他们应该占用<em>剩余空间</em>,因为我已将 UIImageView 的 CHCR 设置为全部 1000。</li>
</ol>

<h1>更新:</h1>

<p>这是在 ImageView 中添加纵横比约束后的 View :</p>

<p> <a href="/image/dU3Ay.png" rel="noreferrer noopener nofollow"><img src="/image/dU3Ay.png" alt="enter image description here"/></a> </p>

<p> <a href="/image/7dGaz.png" rel="noreferrer noopener nofollow"><img src="/image/7dGaz.png" alt="enter image description here"/></a> </p>

<p>几乎完成了,除了 ImageView 不是从左边缘开始的事实。为了解决这个问题,我尝试将 ImageView 的前沿位置设置为 superView 的前沿位置,但这没有帮助。</p>

<p>我怎样才能达到想要的布局?</p></p>
                                    <br><hr><h1><strong>Best Answer-推荐答案</ strong></h1><br>
                                            <p><p>滑动删除部分的工作完全正常。整个单元格向左滑动而不是向左收缩(看看 Mail.app,你会发现它的行为方式相同)。</p>

<p>至于另一个问题,当表格处于编辑模式时, ImageView 是唯一缩小的部分……</p>

<ol>
<li>调低评级 View 和标签的抗压性。</li>
<li>为 ImageView 添加纵横比约束。</li>
<li>选择 ImageView 和内容 View (使用
您截取屏幕截图的大纲 View 中的命令键)并设置
他们有相同的高度。
这应该可以防止 ImageView 在编辑模式下缩小。如果不尝试在单元格顶层的水平堆栈 View 的各种模式。</li>
</ol></p>
                                   
                                                <p style="font-size: 20px;">关于ios - 如何修复官方 iOS 应用开发教程中的 Auto Layout 问题?,我们在Stack Overflow上找到一个类似的问题:
                                                        <a href="https://stackoverflow.com/questions/43819187/" rel="noreferrer noopener nofollow" style="color: red;">
                                                                https://stackoverflow.com/questions/43819187/
                                                        </a>
                                                </p>
                                       
页: [1]
查看完整版本: ios - 如何修复官方 iOS 应用开发教程中的 Auto Layout 问题?