Close Menu
geekfence.comgeekfence.com
    What's Hot

    What Productivity Really Means – O’Reilly

    November 12, 2025

    The EU’s AI Act

    November 12, 2025

    The economics of the software development business

    November 12, 2025
    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

    File upload using Vapor 4

    November 12, 2025

    Transitions in SwiftUI · objc.io

    November 10, 2025

    Keyboard shortcuts for Export Unmodified Original in Photos for Mac – Ole Begemann

    November 9, 2025

    Using Tool Calling to Supercharge Foundation Models

    November 8, 2025

    A deep dive into Collections, Sequences, and Iterators in Swift – Donny Wals

    November 6, 2025

    Create a multi-line, editable text view using TextEditor in SwiftUI. – iOSTutorialJunction

    November 5, 2025
    Top Posts

    Microsoft 365 Copilot now enables you to build apps and workflows

    October 29, 20256 Views

    Here’s the latest company planning for gene-edited babies

    November 2, 20254 Views

    Skills, Roles & Career Guide

    November 4, 20252 Views
    Don't Miss

    What Productivity Really Means – O’Reilly

    November 12, 2025

    We’ve been bombarded with claims about how much generative AI improves software developer productivity: It…

    The EU’s AI Act

    November 12, 2025

    The economics of the software development business

    November 12, 2025

    Sophos Firewall v22 security enhancements – Sophos News

    November 12, 2025
    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

    What Productivity Really Means – O’Reilly

    November 12, 2025

    The EU’s AI Act

    November 12, 2025

    Subscribe to Updates

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

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