swift 将图片保存到本地_[SwiftUI 100 天] Instafilter 基本 UI 和图片导入

535bc2b66609b7176d1a0fa5ff608524.png
译自 https://www. hackingwithswift.com/bo oks/ios-swiftui/building-our-basic-ui
更多内容,欢迎关注公众号 「Swift花园」
喜欢文章?不如来个 ➕三连?关注专栏,关注我

项目的第一步是构建基本的用户接口,对于这个应用来说包括:

  1. 一个 NavigationView ,用以在顶部展示应用的名称
  2. 一个灰色的矩形,显示 “点击以选择图片”,我们导入的图片会放在这里。
  3. 一个 “强度” 滑块,用来控制应用的 Core Image 滤镜的程度,存储从 0.0 到 1.0 的数值。
  4. 一个 “保存” 按钮,用来写入修改后的图片到用户的相册。

一开始用户还没有选择图片,所以对于图片我们需要用可选的 @State 属性。

首先下面两个属性到 ContentView

@State private var image: Image?
@State private var filterIntensity = 0.5

然后修改 body 属性:

NavigationView {
    
    VStack {
    
        ZStack {
    
            Rectangle()
                .fill(Color.secondary)

            // 显示图片
        }
        .onTapGesture {
    
            // 选择图片
        }

        HStack {
    
            Text("强度")
            Slider(value: self.$filterIntensity)
        }.padding(.vertical)

        HStack {
    
            Button("切换滤镜") {
    
                // 切换滤镜
            }

            Spacer()

            Button("保存") {
    
                // 保存图片
            }
        }
    }
    .padding([.horizontal, .bottom])
    .navigationBarTitle("Instafilter")
}

这里有很多的占位符,随着工程的推进,我们逐步填充。

首先,我们聚集到注释:// 显示图片。如果我们选择了图片,会在这里展示,否则显示一个提示,告诉用户点击可以触发图片选择。

你可能会想到替换这个注释的好方法是使用 if let,像下面这样:

if l
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值