首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ContentView (SwiftUI)的背景图像不是子视图,而是具有适当的滚动行为

ContentView (SwiftUI)的背景图像不是子视图,而是具有适当的滚动行为
EN

Stack Overflow用户
提问于 2019-11-04 21:16:30
回答 1查看 966关注 0票数 2

如何获取ContentView的背景图像,而不是其子视图,并保留可滚动内容在NavBar下消失的行为?

我发现,如果我将背景作为修饰符添加到列表或ScrollView中,它不会更改子视图(例如)上的背景。DetailView),但是可滚动的内容不再消失在导航栏下,navbar标题保持不变(见图2)。但是如果我修改了NavigationView,它恢复了滚动内容在导航栏下消失的行为(见图3),但它也改变了所有子视图的背景(见图4)。

我尝试了一个ZStack和图像(“MoonPhoto”),然后列表

但大多数情况下,我尝试了这个ViewModifier结构的不同位置:

代码语言:javascript
复制
struct BackgroundImage: ViewModifier {
    func body(content: Content) -> some View {
        content
            .opacity(0.8)
            .background(Image("history-in-hd-e5eDHbmHprg-unsplash")
            .resizable()
            .scaledToFill())
    }
}

以下是ContentView的主体:

代码语言:javascript
复制
     var body: some View {
        NavigationView {
            List(missions) { mission in
                NavigationLink(destination: MissionView(mission: mission, astronauts: self.astronauts))
                {
                    Image(mission.image)
                        .resizable()
                        .scaledToFit()
                        .frame(width: 50, height: 50)

                    VStack(alignment: .leading) {
                        Text(mission.displayName)
                            .font(.headline)
                        Text(self.showCrew ? self.crewList(mission: mission) : mission.formattedLaunchDate)
                    }
                }
                .navigationBarTitle("Moonshot")
            }
            .navigationBarTitle("Moonshot")
            .navigationBarItems(leading:
                Button(self.showCrew ? "Show Launch date" : "Show crew") {
                    self.showCrew.toggle()
                }
            )
            .modifier(BackgroundImage()) //Modifying List
        } //If you move the above modifier here, the image shows an all subviews too
    }
}

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-11-05 17:21:15

我观察到的主要问题是关于.large DisplayMode for navigationBarTitle修饰符的。我找到了一个适合我自己的解决方案,但这还是一个解决办法。不管怎样,你可以把它看作是一个临时的解决方案。

其主要思想是在VStack中封装列表,并使用.inline显示模式。希望这能帮上忙。

下面是它的外观(也适用于黑暗模式)

代码语言:javascript
复制
import SwiftUI

struct BackgroundImage: ViewModifier {
    func body(content: Content) -> some View {
        content
            .opacity(0.8)
            .background(Image("history-in-hd-e5eDHbmHprg-unsplash")
            .resizable()
            .scaledToFill())
    }
}


struct ContentView: View {
    var body: some View {
        NavigationView {
            VStack {
                List (1...20, id: \.self) { value in
                    NavigationLink(destination: Text("Details \(value)")) {
                        Text("\(value)")
                    }
                }
            }
            .modifier(BackgroundImage())
            .navigationBarTitle("Title", displayMode: .inline)
        }
    }
}

struct ContentView_Previews: PreviewProvider {
    static var previews: some View {
        ContentView()
    }
}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58701184

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档