Close Menu
geekfence.comgeekfence.com
    What's Hot

    ClickFix attackers using new tactic to evade detection, says Microsoft – Computerworld

    March 7, 2026

    M&A Monthly: February/March 2026

    March 7, 2026

    Posit AI Blog: luz 0.4.0

    March 7, 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»SwiftUI can’t have working rounded corners with AsyncImage and ultra-wide images
    iOS Development

    SwiftUI can’t have working rounded corners with AsyncImage and ultra-wide images

    AdminBy AdminNovember 11, 2025No Comments2 Mins Read0 Views
    Facebook Twitter Pinterest LinkedIn Telegram Tumblr Email
    SwiftUI can’t have working rounded corners with AsyncImage and ultra-wide images
    Share
    Facebook Twitter LinkedIn Pinterest Email


    I am trying to display a list of images from panoramic webcams with following display constraints:

    • rounded corners
    • 16/9 aspect ratio
    • center crop scale type (image is centered and cropped to fill available space while maintaining its own aspect ratio)

    following what I achieved in my Android app while still learning SwiftUI:

    AsyncImage( // from Coil library
        model = webcam.illustrationImageUrl,
        contentDescription = null,
        contentScale = ContentScale.Crop,
        modifier = Modifier
            .aspectRatio(16 / 9f)
            .hazeSource(state = hazeState),
    )
    

    I tried using a combination of resizable, scaledToFill, aspectRatio, clipped followed by either clipToShape or background, but to no avail.

    For instance, this code:

    AsyncImage(url: URL(string: webcam.illustrationImageUrl)) { image in
        image
            .resizable()
            .scaledToFill()
            .aspectRatio(16 / 9, contentMode: .fit)
            .clipped()
            .clipShape(.rect(cornerRadius: 16))
    } placeholder: {
        ProgressView()
    }
    

    will results in this:

    SwiftUI can’t have working rounded corners with AsyncImage and ultra-wide images

    screenshot of a working rounded image

    Clearly my rounding corners are in a mess:

    • First image: no rounded corners
    • Second image: clipped rounded corners
    • Third image: fully rounded corners

    My understanding is as follow: shape clipping seems to apply to the source image and not to what is actually visible (after scaling / cropping) or, the View (image container) itself.

    Why? Because the second image shows a bit of its original corners, which results in slightly rounded corners while the second image does not display its original corner due to a much larger width with much content left and right out of the visual bounds. And if you take the last image, it is properly rounded, because it is displayed entirely!

    I also tried switching from scaledToFill to scaledToFit: all images are properly rounded because they are now entirely displayed. But due to their varying dimensions and original aspect ratio, none respect my 16/9 aspect ratio constraint:

    screenshot of working rounded corners but distorted images

    Finally, I also tried wrapping the AsyncImage and even its underlying Image in a ZStack to which I tried both clipToShape and containerShape, but it does not change anything at all.

    Why can’t I achieve the desired result? Thanks for the help!



    Source link

    Share. Facebook Twitter Pinterest LinkedIn Tumblr Email

    Related Posts

    I wish I could be an OpenClaw Maintainer

    March 7, 2026

    Swift factory method design pattern

    March 6, 2026

    react native – How to solve “”xcodebuild” exited with error code 65.“ – error from npx expo run:ios?

    March 5, 2026

    Post | Cocoanetics

    March 1, 2026

    Swift abstract factory design pattern

    February 28, 2026

    Flutter: Force portrait UI on tablets (iOS + Android) even when device is landscape, but avoid letterboxing / black bars

    February 27, 2026
    Top Posts

    Hard-braking events as indicators of road segment crash risk

    January 14, 202619 Views

    Understanding U-Net Architecture in Deep Learning

    November 25, 202518 Views

    How to integrate a graph database into your RAG pipeline

    February 8, 202610 Views
    Don't Miss

    ClickFix attackers using new tactic to evade detection, says Microsoft – Computerworld

    March 7, 2026

    “And all Windows computers should already be restricted so that random, unsigned (not signed by…

    M&A Monthly: February/March 2026

    March 7, 2026

    Posit AI Blog: luz 0.4.0

    March 7, 2026

    Top Reasons to Choose Precisely for SAP and Salesforce Process Automation

    March 7, 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

    ClickFix attackers using new tactic to evade detection, says Microsoft – Computerworld

    March 7, 2026

    M&A Monthly: February/March 2026

    March 7, 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.