SwiftUI直通车系列(5)—— 自定义绘制

简介: SwiftUI直通车系列(5)—— 自定义绘制

一、图形绘制


   首先,在定义SwiftUI组件时,我们可以通过路径的定义绘制其要表现的UI图形,例如要在页面上显示一个菱形图形,示例代码如下:


struct DrawTestView:View {

   var body: some View {

       Path { path in

           let width = 200

           let height = 200

           path.move(to: CGPoint(x: width, y: height))

           path.addLine(to: CGPoint(x: 100, y: 400))

           path.addLine(to: CGPoint(x: 200, y: 600))

           path.addLine(to: CGPoint(x: 300, y: 400))

       }.fill(Color.red)

   }

}


struct ContentView_Previews: PreviewProvider {

   static var previews: some View {

       DrawTestView()

   }

}

效果如下图所示:


image.png


上面的代码很好理解,使用Path在定义View时,move方法用来进行绘制点的移动,简单理解,如果我们将图形的绘制类比与用笔作画,则move方法的作用就是移动笔尖的位置。addLine方法用来向视图上画一条线,定义完了路径后,调用fill方法用来进行图形内部颜色的填充。如上代码所示,实际上我们只画了三条线,系统默认将三条线及最后一个点与原点的连线组成的图形内部进行了颜色的填充,如果我们不对内部进行颜色填充,只将线的颜色显示出来,就更加直观了,代码如下:


struct DrawTestView:View {

   var body: some View {

       Path { path in

           let width = 200

           let height = 200

           path.move(to: CGPoint(x: width, y: height))

           path.addLine(to: CGPoint(x: 100, y: 400))

           path.addLine(to: CGPoint(x: 200, y: 600))

           path.addLine(to: CGPoint(x: 300, y: 400))

       }.stroke(Color.red,lineWidth: 10)

   }

}

效果如下图所示:


image.png


与addLine的使用方法类似,我们还可以通过添加矩形、椭圆、贝塞尔曲线等等方法来绘制图形,示例代码如下:


struct DrawTestView:View {

   var body: some View {

       Path { path in

           let width = 200

           let height = 200

           path.move(to: CGPoint(x: width, y: height))

           path.addLine(to: CGPoint(x: 100, y: 400))

           path.addLine(to: CGPoint(x: 200, y: 600))

           path.addLine(to: CGPoint(x: 300, y: 400))

           path.addRect(CGRect(x: 20, y: 20, width: 30, height: 30))

           path.addEllipse(in: CGRect(x: 60, y: 20, width: 60, height: 30))

           path.addCurve(to: CGPoint(x: 100, y: 100), control1: CGPoint(x: 160, y: 100), control2: CGPoint(x: 60, y: 80))

           path.addRoundedRect(in: CGRect(x: 140, y: 20, width: 50, height: 40), cornerSize: CGSize(width: 20, height: 20))

       }.stroke(Color.red,lineWidth: 3)

   }

}

效果如下图所示:


image.png



目录
相关文章
|
JavaScript Swift 前端开发
历时五天用 SwiftUI 做了一款 APP,阿里工程师如何做的?
2014 年苹果发布会发布 Swift 之后, Swift 经过多年迭代,终于达到了 ABI 稳定版本,也意味着 Swift 做为稳定的得语言,值得用在大型 APP, 用来生产环境中,本文将介绍我们5天用SwiftUI做一款 APP 的过程。
3838 0
历时五天用 SwiftUI 做了一款 APP,阿里工程师如何做的?
|
运维 Swift 开发者
历时五天用 SwiftUI 做了一款 APP,阿里工程师如何做的? | 9月5号栖夜读
今天的首篇文章,讲述了:自 2014 年苹果发布会发布 Swift 之后, Swift 经过多年迭代,终于达到了 ABI 稳定版本,也意味着 Swift 做为稳定的得语言,值得用在大型 APP, 用来生产环境中。
4493 0
|
2月前
|
安全 编译器 Swift
IOS开发基础知识: 对比 Swift 和 Objective-C 的优缺点。
IOS开发基础知识: 对比 Swift 和 Objective-C 的优缺点。
149 2
|
2月前
|
设计模式 前端开发 Swift
使用Swift进行iOS应用开发:深入探索与最佳实践
【5月更文挑战第24天】探索Swift在iOS开发中的深度应用与最佳实践。Swift以其简洁语法、类型安全、面向对象、高性能及与Objective-C的互操作性脱颖而出。使用Xcode设置开发环境,学习Swift语法,创建并设计项目,编写业务逻辑,同时进行调试和测试。遵循MVC模式,利用SwiftUI、并发特性,并注重内存管理,持续学习新工具和技术,以实现高质量应用开发。
|
2月前
|
安全 Swift iOS开发
【Swift 开发专栏】Swift 与 UIKit:构建 iOS 应用界面
【4月更文挑战第30天】本文探讨了Swift和UIKit在构建iOS应用界面的关键技术和实践方法。Swift的简洁语法、类型安全和高效编程模型,加上与UIKit的紧密集成,使开发者能便捷地创建用户界面。UIKit提供视图、控制器、布局、动画和事件处理等功能,支持灵活的界面设计。实践中,遵循设计原则,合理组织视图层次,运用布局和动画,以及实现响应式设计,能提升界面质量和用户体验。文章通过登录、列表和详情界面的实际案例展示了Swift与UIKit的结合应用。
|
2月前
|
存储 Swift iOS开发
使用Swift开发一个简单的iOS应用的详细步骤。
使用Swift开发iOS应用的步骤包括:创建Xcode项目,设计界面(Storyboard或代码),定义数据模型,实现业务逻辑,连接界面和逻辑,处理数据存储(如Core Data),添加网络请求(必要时),调试与测试,根据测试结果优化改进,最后提交至App Store或其它平台发布。
61 0
|
2月前
|
存储 安全 Swift
【Swift 开发专栏】使用 Swift 开发一个简单的 iOS 应用
【4月更文挑战第30天】本文介绍了使用 Swift 开发简单 iOS 待办事项应用的步骤。首先,阐述了 iOS 开发的吸引力及 Swift 语言的优势。接着,详细说明了应用的需求和设计,包括添加、查看和删除待办事项的功能。开发步骤包括创建项目、界面搭建、数据存储、功能实现,并提供了相关代码示例。最后,强调了实际开发中需注意的细节和优化,旨在帮助初学者掌握 Swift 和 iOS 开发基础。
|
2月前
|
监控 API Swift
用Swift开发iOS平台上的上网行为管理监控软件
在当今数字化时代,随着智能手机的普及,人们对于网络的依赖日益增加。然而,对于一些特定场景,如家庭、学校或者企业,对于iOS设备上的网络行为进行管理和监控显得尤为重要。为了满足这一需求,我们可以利用Swift语言开发一款iOS平台上的上网行为管理监控软件。
224 2
|
2月前
|
监控 Swift iOS开发
局域网计算机监控软件中利用Swift构建iOS端的移动监控应用
在局域网计算机监控软件的开发中,构建iOS端的移动监控应用是一项关键任务。本文将介绍如何利用Swift语言实现这一目标,通过多个代码示例展示关键功能的实现。
237 1
|
2月前
|
安全 JavaScript 前端开发
IOS开发基础知识:介绍一下 Swift 和 Objective-C,它们之间有什么区别?
IOS开发基础知识:介绍一下 Swift 和 Objective-C,它们之间有什么区别?
106 0