38 SwiftUI

简介: SwiftUI

SwiftUI

image.png

  • SwiftUI 是一种基于Swift的强大能力,简单创新的构建用户界面的方法,并且可以运行在苹果所有的平台上

image.png

SwiftUI - 声明式语法

  • SwiftUI采用声明式语法,因为你可以简单声明你的用户界面

image.png

  • Xcode11提供了强大的设计工具,可以通过简单的拖拽用SwiftUI生成用户界面

image.png

  • 只需要描述一次的布局-为你的视图声明任何状态的内容和布局,一旦状态发生改变,SwiftUI会自动更新视图的渲染
  • 构建可复用的组件-将小型、独立视图组合到更大,更复杂的界面中。在任何为Apple平台所设计的应用之间,共享您的自定义视图
  • 精简动画-创建平滑的动画就像调用单个方法一样简单。SwiftUI会在必要时自动计算并过渡动画


SwiftUI设计工具使用指南

创建项目

image.png

Stacks

image.png

如何使用SwiftUI构建可复用的组件

地标页例子

image.png

Image组件

image.png

image.png

image.pngimage.png


structContentView: View {
varbody: someView {
VStack {
//设置安全距离MapView().edgesIgnoringSafeArea(.all)
                .frame(height: 300)
CircleImage().offset(y: -130).padding(.bottom, -130)
//左对齐VStack (alignment: .leading) {
Text("圆明园").font(.title)
HStack {
Text("皇家园林").font(.subheadline)
Spacer()
Text("北京").font(.subheadline)
                }
            }.padding()//边界留白Spacer()//留白        }
    }
}

图片组件

structCircleImage: View {
varbody: someView {
//将图片剪切出一个圆Image("ymy").clipShape(Circle())
//加一个边框线        .overlay(Circle().stroke(Color.black, lineWidth: 4))
        .shadow(radius: 10)//阴影    }
}

地图组件

importSwiftUIimportMapKitstructMapView; UIViewRepresentable {
//创建地图组件funcmakeUIView(context: Context) ->MKMapView {
returnMKMapView(frame: .zero)
    }
//对地图组件进行设置funcupdateUIView(_uiView: MKMapView, context: Context) {
//圆明园的经纬度letlocation=CLLocationCoordinate2D(latitude: 40.00491139888854, longitude: 116.2896180152893)
//展示范围letspan=MKCoordinateSpan(latitudeDelta: 0.5, longitudeDelta: 0.5)
letregion=MKCoordinateRegion(center: location, span: span)
uiView.setRegion(region, animated: true)
    }
}

如何使用SwiftUI实现动画

SwiftUI - 动画

  • 在SwiftUI中,你可以将任意的改变过程封装进一个withAnimation块中。默认,SwiftUI会对这种改变采用fade in/out 的方式进行动画
structAnimationView: View {
//状态 当属性改变时, 会进行重写渲染@StateprivatevarshowDetail=falsevarbody: someView {
Button(action: {
withAnimation {
self.showDetail=!self.showDetail            }
        }) {
Image(systemName: "chevron.right.circle")//使用了一张系统图片                .imageScale(.large)//尺寸                .rotationEffect(.degrees(showDetail?90 : 0))//旋转90度或0度                .scaleEffect(showDeatil?1.5 : 1)//放大倍数            .padding()
        }
    }
}

在这里更改显示入口

image.png

深入理解SwiftUI:实现原理探秘

@propertyWrapper

  • 通过property Wrapper机制,对一些类似的属性的实现代码做同一封装
  • 通过@propertyWrapper可以移除掉一些重复或者类似的代码

@state

  • 通过@State SwiftUI 实现了值的绑定、动态查找和View的自动重现绘制

image.png

image.png

  • 课后题:查看源码,了解@Binding,@ObservedObject,@EnvironmentObject等装饰器的作用
extensionUserDefaults {
publicenumKeys {
staticlethadShownUserGuide="hadShownUserGuide"    }
varhadShownUserGuide: Bool {
set {
set(newValue, forKey: Keys.hadShownUserGuide)
        }
get {
bool(forKey: Keys.hadShownUserGuide)
        }
    }
}
structPropertyWrapperView: View {
@StateprivatevarshowText=UserDefaults.standard.hasShownUserGuide?"已经展示" : "没有展示过"varbody: someView {
Button(action: {
if (!UserDefaults.standard.hasShownUserGuide) {
UserDefaults.standard.hasShownUserGuide=trueself.showText="已经展示"            }
        }) {
Text(self.showText)
        }
    }
}
  • 使用propertyWrapper进行统一扩展
@propertyWrapperstructUserDefaultsWrapper<T> {
varkey: StringvardefaultValue : Tinit(_key: String, defaultValue: T) {
self.key=keyself.defaultValue=defaultValue    }
varwrappedValue: T {
get {
returnUserDefaults.standard.value(forKey: key) as?T??defaultValue        }
set {
UserDefaults.standard.set(newValue, forKey: key)
        }
    }
}
structPropertyWrapperView: View {
@UserDefaultsWrapper("hadShownUserGuide", defaultValue: false)
staticvarhadShownUserGuide : Bool@StateprivatevarshowText=PropertyWrapperView.hasShownUserGuide?"已经展示" : "没有展示过"varbody: someView {
Button(action: {
if (!PropertyWrapperView.hasShownUserGuide) {
PropertyWrapperView.hasShownUserGuide=trueself.showText="已经展示"            }
        }) {
Text(self.showText)
        }
    }
}








目录
相关文章
SwiftUI—快速制作一个缩放动画
SwiftUI—快速制作一个缩放动画
905 0
SwiftUI—快速制作一个缩放动画
|
存储 iOS开发
SwiftUI极简教程17:Gestures手势的使用
SwiftUI极简教程17:Gestures手势的使用
804 0
SwiftUI极简教程17:Gestures手势的使用
|
8天前
|
编译器 API Swift
【Swift开发专栏】Swift中的SwiftUI框架初探
【4月更文挑战第30天】SwiftUI是苹果2019年推出的界面构建框架,简化iOS应用开发。通过声明式语法和编译器优化,提供直观高效的UI设计。本文将介绍SwiftUI概述、主要特性及实际案例。SwiftUI强调“少即是多”,用少量代码实现复杂界面,提供简洁API、自动布局、双向数据绑定等功能。通过视图组合和实时预览加速开发。案例展示如何用SwiftUI构建用户列表界面,体现其结构清晰、易扩展的优势。SwiftUI在iOS开发中的重要性日益提升。
|
8天前
|
API iOS开发 UED
SwiftUI 设计
SwiftUI 设计
42 2
|
8天前
|
存储 监控 算法
大师学SwiftUI第12章 - 手势 Part 1
手势是用户在屏幕上执行的动作,如点击、滑动或捏合。这些手势很难识别,因为屏幕上只能返回手指的位置。为此,Apple提供了手势识别器。手势识别器完成所有识别手势所需的计算。所以我们不用处理众多的事件和值,只需在等待系统监测到复杂手势时发送通知并进行相应处理即可。
32 0
|
8天前
|
存储 编解码 vr&ar
大师学SwiftUI第12章 - 手势 Part 2
放大手势常被称为捏合手势,因为常常在用户张开或捏合两个手指时进行识别。通常这个手势实现用于让用户放大或缩小图片。
29 0
|
6月前
|
存储 vr&ar Swift
大师学SwiftUI第16章 - UIKit框架集成
SwiftUI是一套新框架,因此并没有包含我们构建专业应用所需的所有工具。这意味着我们会需要求助于UIKit(移动设备)和AppKit(Mac电脑)等原生框架所提供的工具。
44 0
|
6月前
|
存储 自然语言处理 vr&ar
大师学SwiftUI第20章 - 国际化
苹果的产品遍布一百多个国家,使用几十种语言和方言发行应用,但通常我们只能创建一个版本的应用,所以就需要对不同市场进行适配。这不仅仅是翻译,还有用户界面中元素的排列、数字的格式等等。这一客制化的过程称为本地化。在SwiftUI中,大多数本地化会自动完成。例如,SwiftUI视图的内容采用靠前(leading)和靠后(trailing)约束来根据文字顺序(从左到右或从右到左读)的不同来表示左和右,日期和充其量单位等值会自动根据所在地进行格式化(参见示例4-32)。但文本还是需要我们来翻译。为此Xcode提供了字符串名录(String Catalogs)。
65 0
|
存储 JSON 安全
SwiftUI100天:使用SwiftUI搭建一个每日一句App
在本章中,你将学会使用SwiftUI搭建一个每日一句App。
311 0
SwiftUI100天:使用SwiftUI搭建一个每日一句App
|
存储
SwiftUI100天:使用SwiftUI搭建一个计时器App
在本章中,你将学会使用SwiftUI搭建一个计时器App。
533 0
SwiftUI100天:使用SwiftUI搭建一个计时器App

热门文章

最新文章