在 SwiftUI 中 accessibilityChildren 视图修饰符的作用

前言

SwiftUI 为我们提供了一系列丰富的视图修饰符,用于操作视图的可访问性树。我已经介绍了其中许多,你可以在博客中找到它们。本文我们将讨论 accessibilityChildren 视图修饰符以及我们如何从中受益。

accessibilityChildren 视图修饰符允许我们为视图创建一个可访问性容器,并使用 ViewBuilder 闭包提供的视图元素进行填充。

示例

让我们来看一个简单的示例。

swift 复制代码
struct BarChartShape: Shape {
    let dataPoints: [DataPoint]
    
    func path(in rect: CGRect) -> Path {
        Path { p in
            let spacing: CGFloat = 10  // 间距为 10 像素
            let totalSpacing = CGFloat(dataPoints.count - 1) * spacing
            let availableWidth = rect.size.width - totalSpacing
            let width: CGFloat = availableWidth / CGFloat(dataPoints.count)
            var x: CGFloat = 0
            
            for point in dataPoints {
                let pointRect = CGRect(
                    x: x,
                    y: rect.size.height - point.value,
                    width: width,
                    height: point.value
                )
                let pointPath = RoundedRectangle(cornerRadius: 8).path(in: pointRect)
                p.addPath(pointPath)
                x += width + spacing  // 添加间距
            }
        }
    }
}

如你在上面的示例中所见,我们有一个绘制数据点的形状类型。我们无法为每个数据点提供可访问性值,因为在描边或填充形状后,该形状将成为一个单一视图。

accessibilityChildren 使用

不过,SwiftUI 为这种情况专门提供了 accessibilityChildren 视图修饰符。

swift 复制代码
struct ContentView: View {
    @State private var dataPoints: [DataPoint] = [
        .init(value: 200),
        .init(value: 300),
        .init(value: 50),
        .init(value: 600),
        .init(value: 500)
    ]
    
    var body: some View {
        BarChartShape(dataPoints: dataPoints)
            .fill(.red)
            .accessibilityLabel("Chart")
            .accessibilityChildren {
                HStack(alignment: .bottom, spacing: 0) {
                    ForEach(dataPoints) { point in
                        RoundedRectangle(cornerRadius: 8)
                            .accessibilityValue(Text(point.value.formatted()))
                    }
                }
            }
    }
}

通过应用 accessibilityChildren 视图修饰符,我们创建了一个可访问性容器,并使用 ViewBuilder 闭包中提供的视图元素进行填充。SwiftUI 不会渲染我们通过 ViewBuilder 闭包传递的视图,它仅用于填充可访问性树的子元素。

accessibilityChildrenaccessibilityRepresentation 视图修饰符之间的主要区别在于前者不会影响视图本身。它仅为子元素创建一个可访问性容器,而 accessibilityRepresentation 视图修饰符会完全替换当前视图的可访问性树。

完整代码

首先,你需要定义 DataPoint 结构体,然后可以在 ContentView 中初始化 dataPoints 数组。以下是完善后的代码:

swift 复制代码
import SwiftUI

struct DataPoint: Identifiable {
    var id = UUID()
    var value: CGFloat
}

struct BarChartShape: Shape {
    let dataPoints: [DataPoint]
    
    func path(in rect: CGRect) -> Path {
        Path { p in
            let width: CGFloat = rect.size.width / CGFloat(dataPoints.count)
            var x: CGFloat = 0
            
            for point in dataPoints {
                let pointRect = CGRect(
                    x: x,
                    y: rect.size.height - point.value,
                    width: width,
                    height: point.value
                )
                let pointPath = RoundedRectangle(cornerRadius: 8).path(in: pointRect)
                p.addPath(pointPath)
                x += width
            }
        }
    }
}

struct ContentView: View {
    @State private var dataPoints: [DataPoint] = [
        .init(value: 20),
        .init(value: 30),
        .init(value: 5),
        .init(value: 100),
        .init(value: 80)
    ]
    
    var body: some View {
        BarChartShape(dataPoints: dataPoints)
            .fill(Color.red)
            .accessibilityLabel("Chart")
            .accessibilityChildren {
                HStack(alignment: .bottom, spacing: 0) {
                    ForEach(dataPoints) { point in
                        RoundedRectangle(cornerRadius: 8)
                            .fill(Color.blue)  // You can change the color here
                            .frame(width: 20, height: point.value)
                            .accessibilityValue(Text(String(Int(point.value)))
                        }
                    }
                }
            }
        }
    }

上述代码已添加了所需的 DataPoint 结构体和 ContentView,并通过 BarChartShape 创建了柱状图。此代码将以红色柱状图的形式显示数据点,每个数据点的值决定柱状的高度,同时也包括辅助功能信息以提供无障碍体验。

请注意,柱状图的颜色可以通过 .fill(Color.red) 进行自定义。在上述代码中,将柱状图填充颜色设为红色。您可以根据需要自行更改填充颜色。

运行截图:

总结

今天,我们了解了 SwiftUI 为我们提供的又一个强大的可访问性视图修饰符。SwiftUI 凭借提供如此多友好的 API,简化了我们为了使我们的应用对每个人都具有可访问性而必须做的工作,做得非常出色。

相关推荐
OKXLIN5 小时前
IOS UITextField 无法隐藏键盘问题
ios·objective-c
AL.千灯学长13 小时前
DeepSeek接入Siri(已升级支持苹果手表)完整版硅基流动DeepSeek-R1部署
人工智能·gpt·ios·ai·苹果vision pro
openinstall全渠道统计1 天前
免填邀请码工具:赋能六大核心场景,重构App增长新模型
android·ios·harmonyos
早起的年轻人2 天前
Flutter CupertinoNavigationBar iOS 风格导航栏的组件
flutter·ios
貂蝉空大2 天前
uni-app开发安卓和ios app 真机调试
android·ios·uni-app
胖虎12 天前
iOS 中的圆角与平滑圆角:从新特性到老项目适配
ios·圆角·平滑圆角·cornercurve
志飞2 天前
ios UICollectionView使用自定义UICollectionViewCell
ios·collectionview·自定义cell
Neo Evolution2 天前
Flutter与移动开发的未来:谷歌的技术愿景与实现路径
android·人工智能·学习·ios·前端框架·webview·着色器
没头脑的ht3 天前
ios App的启动过程和启动优化
ios
敲代码的鱼哇3 天前
设备唯一ID获取,支持安卓/iOS/鸿蒙Next(uni-device-id)UTS插件
android·ios·uniapp·harmonyos