SwiftUI 中的 scaleEffect 修饰器

SwiftUI 中的 scaleEffect 修饰器

scaleEffect 是 SwiftUI 中用于调整视图缩放比例的修饰器,它可以让视图在二维平面上进行放大或缩小变换。

基本用法

1. 统一缩放

swift 复制代码
// 整体放大1.5倍
Image("example")
    .scaleEffect(1.5)

// 整体缩小到0.8倍
Text("Hello")
    .scaleEffect(0.8)

2. 分别指定x/y轴缩放

swift 复制代码
// 水平放大1.2倍,垂直缩小到0.9倍
Circle()
    .scaleEffect(x: 1.2, y: 0.9)

3. 带锚点的缩放

swift 复制代码
// 以视图顶部中心点为锚点放大
Rectangle()
    .scaleEffect(1.5, anchor: .top)

高级用法

结合动画

swift 复制代码
@State private var scaled = false

Button("点击缩放") {
    withAnimation(.spring()) {
        scaled.toggle()
    }
}
.scaleEffect(scaled ? 1.5 : 1.0)

组合其他变换

swift 复制代码
// 缩放+旋转组合
RoundedRectangle(cornerRadius: 10)
    .scaleEffect(0.8)
    .rotationEffect(.degrees(45))

响应手势

swift 复制代码
@State private var currentScale: CGFloat = 1.0

Image("photo")
    .scaleEffect(currentScale)
    .gesture(MagnificationGesture()
        .onChanged { value in
            currentScale = value
        }
    )

注意事项

  1. scaleEffect 不会改变视图的原始布局空间,缩放后的视图仍会占据原始位置和大小的空间
  2. 对于需要改变布局空间的情况,可以考虑使用 frametransformEffect
  3. 过度缩放可能导致内容模糊,特别是对于位图图像

scaleEffect 是创建动态界面和交互效果的强大工具,常用于按钮反馈、焦点突出和过渡动画等场景。

相关推荐
Moment21 小时前
Vibe Coding 时代,到底该选什么样的工具来提升效率❓❓❓
前端·后端·github
IT_陈寒1 天前
SpringBoot性能飙升200%?这5个隐藏配置你必须知道!
前端·人工智能·后端
小时前端1 天前
React性能优化的完整方法论,附赠大厂面试通关技巧
前端·react.js
Nicko1 天前
Jetpack Compose BOM 2026.02.01 解读与升级指南
前端
小蜜蜂dry1 天前
nestjs学习 - 控制器、提供者、模块
前端·node.js·nestjs
优秀稳妥的JiaJi1 天前
基于腾讯地图实现电子围栏绘制与校验
前端·vue.js·前端框架
前端开发呀1 天前
从 qiankun(乾坤) 迁移到 Module Federation(模块联邦),对MF只能说相见恨晚!
前端
没想好d1 天前
通用管理后台组件库-10-表单组件
前端
恋猫de小郭1 天前
你用的 Claude 可能是虚假 Claude ,论文数据告诉你,Shadow API 中的欺骗性模型声明
前端·人工智能·ai编程
_Eleven1 天前
Pinia vs Vuex 深度解析与完整实战指南
前端·javascript·vue.js