- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想制作一个可在 SwiftUI 中使用的自定义 ScrollView ,它允许我设置滚动位置。我进行了一半,遇到了 ScrollView 在滚动时无法在状态栏下正确流动的问题。
问题是这样的:
在进行测试以查看问题所在时,我制作了一个基于 Storyboard的比较项目,该项目根本没有代码,只是一个与我在代码中的结构完全相同的结构。结果看起来像这样,这是我想要实现的:
似乎 Root View Controller View 没有一直到达顶部,但我不明白为什么。所有其他自动滚动插入魔术都可以正常工作。
这是我的代码,您可以在 Xcode 11 中使用 SwiftUI 创建一个新项目并将其粘贴到 ContentView.swift 中。
import SwiftUI
import UIKit
class UIScrollableViewController: UIViewController {
let scrollView = UIScrollView()
let contentController: UIViewController
init(contentController: UIViewController) {
self.contentController = contentController
super.init(nibName: nil, bundle: nil)
}
required init?(coder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
override func viewDidLoad() {
super.viewDidLoad()
view.addSubview(scrollView)
// Add child controller
scrollView.addSubview(contentController.view)
addChild(contentController)
let contentView = contentController.view!
// Constrain scroll view
scrollView.translatesAutoresizingMaskIntoConstraints = false;
scrollView.leadingAnchor.constraint(equalTo: view.leadingAnchor, constant: 0).isActive = true
scrollView.topAnchor.constraint(equalTo: view.topAnchor, constant: 0).isActive = true
scrollView.trailingAnchor.constraint(equalTo: view.trailingAnchor, constant: 0).isActive = true
scrollView.bottomAnchor.constraint(equalTo: view.bottomAnchor, constant: 0).isActive = true
// Constrain child view to scroll view
contentView.translatesAutoresizingMaskIntoConstraints = false
contentView.leadingAnchor.constraint(equalTo: scrollView.leadingAnchor).isActive = true
contentView.topAnchor.constraint(equalTo: scrollView.topAnchor).isActive = true
contentView.trailingAnchor.constraint(equalTo: scrollView.trailingAnchor).isActive = true
contentView.bottomAnchor.constraint(equalTo: scrollView.bottomAnchor).isActive = true
// Constrain width of child view to width of self.view, NOT scroll view
contentView.widthAnchor.constraint(equalTo: view.widthAnchor).isActive = true
}
}
class ScrollableNavigationController: UINavigationController, UINavigationBarDelegate {
}
struct ScrollableNavigationViewController<Content: View>: UIViewControllerRepresentable {
typealias UIViewControllerType = ScrollableNavigationController
let hostingController: UIHostingController<Content>
let scrollableContainer: UIScrollableViewController!
init(@ViewBuilder content: () -> Content) {
hostingController = UIHostingController(rootView: content())
scrollableContainer = UIScrollableViewController(contentController: hostingController)
scrollableContainer.title = "Scrollable"
}
func makeUIViewController(context: UIViewControllerRepresentableContext<ScrollableNavigationViewController>) -> ScrollableNavigationController {
let navigationController = ScrollableNavigationController(rootViewController: scrollableContainer)
navigationController.navigationBar.prefersLargeTitles = true
return navigationController
}
func updateUIViewController(_ navigationController: ScrollableNavigationController, context: UIViewControllerRepresentableContext<ScrollableNavigationViewController>) {
}
}
struct ScrollableNavigationView<Content: View>: View {
var content: Content
init(@ViewBuilder content: () -> Content) {
self.content = content()
}
var body: some View {
ScrollableNavigationViewController {
content
}
}
}
// MARK: Test
struct BoxView: View {
var colors: [Color] = [.red, .blue, .orange, .pink, .yellow]
var body: some View {
ForEach(0 ..< 20) { i in
ZStack {
Rectangle()
.fill(self.colors[i % 5])
.padding()
.frame(height: 130)
Text("\(i)")
.font(.title)
}
}
}
}
struct ContentView: View {
var body: some View {
ScrollableNavigationView {
BoxView()
}
}
}
struct ContentView_Previews: PreviewProvider {
static var previews: some View {
ContentView()
}
}
最佳答案
问题似乎出在场景委托(delegate)上,它导致整个 View 层次结构被包裹在 UIHostingController
中,它具有嵌套的 SwiftUI Controller 似乎能够避免的嵌入魔法。为了证明这一点,我想出了一个稍微有点老套的解决方案。
替换这个:
window.rootViewController = UIHostingController(rootView: ContentView())
与:
window.rootViewController = MyHostingController(rootView: ContentView())
MyHostingController
看起来像这样:
class MyHostingController<Content: View>: UIHostingController<Content> {
override func viewDidLayoutSubviews() {
super.viewDidLayoutSubviews()
view.subviews[0].frame = UIScreen.main.bounds
}
}
从 iOS 13.1 开始,您似乎真的应该只尝试在两层 UIKit 之间集成 SwiftUI,而不是相反。 SwiftUI 在其内部包含太多未记录的魔法。
关于iOS 13 : Scroll view inside navigation controller won't go under the status bar,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58241095/
我对文档有点困惑。请纠正我。 git 状态- 显示当前本地工作目录状态 git status -u- 显示未跟踪的文件(也是本地的) git 状态 -uno- 不显示未跟踪的文件(也是本地的)?? 后
我有一个具有 12 个虚拟机资源的 ARM 模板。每个虚拟机都有 1 个与其关联的 CustomLinuxScript 扩展资源。 某些 CustomLinuxScript 扩展失败并出现错误:状态文
我有一个具有 12 个虚拟机资源的 ARM 模板。每个虚拟机都有 1 个与其关联的 CustomLinuxScript 扩展资源。 某些 CustomLinuxScript 扩展失败并出现错误:状态文
我有以下 JavaScript 代码: alert(data.status); data 是一个 JSON 对象,其字段之一是 status ( bool 字段)。 当JSON.stringify(d
我在验证表单时遇到此错误,如何解决它。 代码: app.post('/',[ check('username','Error occured in Username').trim().isEmai
我正在开发一个使用 fork() exec() wait() 的 C 程序。第一个进程有以下代码: int main(int argc, const char * argv[]) { // inser
我想在 git status 上运行 linter,但是似乎没有 pre-status 和 post-status Hook 。 如何给 git 添加一个钩子(Hook)? fine docs对此事保
我需要获取所有 current_user.friends 状态,然后按 created_at 对它们进行排序。 class User a.created_at } end current_user.
我在 Eloquent 中使用 orWhere 时遇到问题。 我有一个团队,这个团队有一些资料。我想获取状态 = 1 或状态 = 2 的所有配置文件。但我无法让它工作。 我的代码是这样的: $prof
http://refspecs.linuxfoundation.org/LSB_5.0.0/LSB-Core-generic/LSB-Core-generic.html#INISCRPTACT 根据这
我们在 IIS 6.0 上托管 WCF 服务的服务器之一上观察到以下行为: IIS 日志显示所用时间的值较高 (> 100000) HTTP 状态码是 200 sc-win32-status 代码显示
在 Dynamics CRM 中,潜在客户实体同时具有状态和状态原因。使用 API 我可以获得所有状态原因。我被绊倒的地方是当我的用户选择状态原因时我想倒退并找出哪个状态与所选状态原因相关联。 以下是
我很好奇返回响应和仅创建响应的区别。 我见过大量使用 return res.status(xxx).json(x) 的代码示例和res.status(xxx).json(x) . 谁能详细解释一下两者
文档并没有真正说明 status 是什么。 status 到底是什么? http://man7.org/linux/man-pages/man2/exit_group.2.html 最佳答案 来自ex
An earlier question导致了一些关于如何检查 Git 存储库是否包含脏索引或未跟踪文件的想法。我从那次讨论中采纳的答案如下: #!/bin/sh exit $(git status -
ECSHOP出现 XMlHttpRequest status:[500] Unknow status 这个错误 把/admin/templates/top.htm 这个文件中{insert_scr
我有以下代码用于通过 Twitter4J 获取推文: List statuses; Paging paging = new Paging(1, LIMIT); statuses = twitter.g
非常不言自明。我正在制作一个脚本并且遇到了被使用和解析的情况,但它们的输出似乎总是完全相同。 最佳答案 git status --branch --porcelain "显示分支的状态(ahead,
我有一张表,上面有如下记录 表A subid clickid status datetime 1 123 low 2018-07-24 20:20:44 2 123
如果确实缺少资源,我的 API 将返回以下内容 { "code": 404, "message": "HTTP 404 Not Found" } 当我使用代码 Response.sta
我是一名优秀的程序员,十分优秀!