Close Menu
geekfence.comgeekfence.com
    What's Hot

    SpaceX IPO: Everything you need to know

    June 12, 2026

    Brain-inspired chip runs near absolute zero and could transform quantum computing

    June 12, 2026

    Now available: Amazon EC2 M9g and M9gd instances powered by new AWS Graviton5 processors

    June 12, 2026
    Facebook X (Twitter) Instagram
    • About Us
    • Contact Us
    Facebook Instagram
    geekfence.comgeekfence.com
    • Home
    • UK Tech News
    • AI
    • Big Data
    • Cyber Security
      • Cloud Computing
      • iOS Development
    • IoT
    • Mobile
    • Software
      • Software Development
      • Software Engineering
    • Technology
      • Green Technology
      • Nanotechnology
    • Telecom
    geekfence.comgeekfence.com
    Home»iOS Development»ios – Centered ScrollView content doesn’t return to position after pull-to-refresh with a large navigation title in SwiftUI
    iOS Development

    ios – Centered ScrollView content doesn’t return to position after pull-to-refresh with a large navigation title in SwiftUI

    AdminBy AdminJune 12, 2026No Comments2 Mins Read2 Views
    Facebook Twitter Pinterest LinkedIn Telegram Tumblr Email
    ios – Centered ScrollView content doesn’t return to position after pull-to-refresh with a large navigation title in SwiftUI
    Share
    Facebook Twitter LinkedIn Pinterest Email


    It may be the modifier .containerRelativeFrame that is causing this problem. For content inside a ScrollView, the “container” is the ScrollView, but I am guessing that the size may change when a refresh is being performed and the activity indicator is showing.

    I would suggest using a GeometryReader to measure the height of the area occupied by the ScrollView. Then:

    • set the height of the ScrollView as the minimum height for the VStack
    • the maximum width of the VStack can simply be set to .infinity
    • the modifier .containerRelativeFrame can be removed.

    You said you tried using a GeometryReader already and it didn’t work. However, you didn’t show how you tried it. Give it a try as follows:

    NavigationStack {
        GeometryReader { geo in
            ScrollView(.vertical) {
                VStack(spacing: 30) {
                    // ...
                }
                .frame(maxWidth: .infinity, minHeight: geo.size.height)
            }
        }
        .refreshable {
            try? await Task.sleep(for: .seconds(2))
        }
        .navigationTitle("Title")
    }
    

    Animation


    You will notice from the gif above that the content inside the ScrollView jumps around in a jerky way when the activity indicator disappears and the content slides back up to fill the space. The reason for the sudden movement may be because there is some native animation involved (the title slides up smoothly) but the height of the VStack is being changed without animation, so the change in height is sudden.

    To smooth out the movement, you could try to animate the change in height, but it is difficult to synchronize this with the native animation. Special measures are also needed when the view is first shown, otherwise the animation applied to the height causes the content to slide into position in a way that may not be desirable.

    An alternative and perhaps simpler approach is to use a fixed amount of top padding to move the placeholder content closer to the center of the screen, instead of trying to center it exactly by setting a minimum height. Something like:

    VStack(spacing: 30) {
        // ...
    }
    .frame(maxWidth: .infinity)
    .padding(.top, geo.size.height > 400 ? 200 : 60)
    

    The movement is much smoother with this approach:

    Animation



    Source link

    Share. Facebook Twitter Pinterest LinkedIn Tumblr Email

    Related Posts

    Introducing SwiftBash | Cocoanetics

    June 8, 2026

    ios – SwiftUI Map View freezes when there is no network

    June 7, 2026

    Swift Cross Platform | Cocoanetics

    June 3, 2026

    Is there any way to redeem in-app purchases in iOS apps as the developer of the app?

    June 2, 2026

    An Interpreter for Swift | Cocoanetics

    May 29, 2026

    ios – Why does the view’s internal state is not updated for first mutation when doing it via an Computed Binding

    May 28, 2026
    Top Posts

    Understanding U-Net Architecture in Deep Learning

    November 25, 202552 Views

    Hard-braking events as indicators of road segment crash risk

    January 14, 202630 Views

    Redefining AI efficiency with extreme compression

    March 25, 202627 Views
    Don't Miss

    SpaceX IPO: Everything you need to know

    June 12, 2026

    SpaceX has captured the attention of media, investors, and the public for years now —…

    Brain-inspired chip runs near absolute zero and could transform quantum computing

    June 12, 2026

    Now available: Amazon EC2 M9g and M9gd instances powered by new AWS Graviton5 processors

    June 12, 2026

    From external espionage to domestic targeting

    June 12, 2026
    Stay In Touch
    • Facebook
    • Instagram
    About Us

    At GeekFence, we are a team of tech-enthusiasts, industry watchers and content creators who believe that technology isn’t just about gadgets—it’s about how innovation transforms our lives, work and society. We’ve come together to build a place where readers, thinkers and industry insiders can converge to explore what’s next in tech.

    Our Picks

    SpaceX IPO: Everything you need to know

    June 12, 2026

    Brain-inspired chip runs near absolute zero and could transform quantum computing

    June 12, 2026

    Subscribe to Updates

    Please enable JavaScript in your browser to complete this form.
    Loading
    • About Us
    • Contact Us
    • Disclaimer
    • Privacy Policy
    • Terms and Conditions
    © 2026 Geekfence.All Rigt Reserved.

    Type above and press Enter to search. Press Esc to cancel.