主頁 >  其他 > SwiftUI之深入決議如何創建和組合視圖

SwiftUI之深入決議如何創建和組合視圖

2021-12-19 08:14:44 其他

一、創建專案并體驗畫布

① 系統要求

  • 創建 SwiftUI 專案工程,體驗畫布、預覽模式和 SwiftUI 模板代碼;
  • 要想在 Xcode 中預覽畫布中的視圖,或者與畫布中的視圖進行互動,需要 Mac 系統版本號不低于 macOS Catalina 10.15,

在這里插入圖片描述

② 步驟

  • 打開 Xcode,在啟動頁面點擊創建新工程,或者在選單中選擇檔案->新建->專案:

在這里插入圖片描述

在這里插入圖片描述

  • 在專案模板選擇器中,選擇 iOS 作為專案平臺,選項單視圖應用(App)作為專案模板,并點擊下一步(Next):

在這里插入圖片描述

  • 輸入專案名稱 FirstSwiftUI,選擇 SwiftUI 作為用戶界面的創建方式,并點擊下一步 Next,在磁盤目錄下選擇一個位置用來存放新創建的工程專案:

在這里插入圖片描述

  • 工程創建好并打開后,在檔案導航器中,選擇 ContentView.swift 檔案,可以瀏覽一下 SwiftUI 視圖的組成結構,默認情況下,SwiftUI 的視圖檔案包含兩個結構體 Struct:
    • 第一個結構體遵循 View 協議,描述視圖的內容和布局;
    • 第二個結構體宣告為第一個視圖的預覽視圖,

在這里插入圖片描述

  • 在**畫布(Canvas)上,點擊恢復(Resume)**按鈕可以顯示預覽視圖,也可以使用快捷鍵 Command+Option+P(如果工程中沒有出現畫布 Canvas,可以選擇選單:編輯器 Editor -> 編輯器和畫布 Canvas,打開畫布進行預覽):

在這里插入圖片描述

  • 在 body 屬性內部,修改文字 Hello, world! 為其它的不同的文字,當在改變代碼的同時,預覽視圖也會實時的更新對應的內容變化:

在這里插入圖片描述

二、定制文本視圖 Text View

① 通過修改代碼來改變視圖的顯示樣式

  • 可以通過修改代碼來改變一個視圖的顯示樣式,也可以通過檢查器獲取視圖可修改屬性,然后再寫對應的代碼改變樣式,在創建應用的程序中,可以同時使用原始碼編輯器、畫布或者檢查器,無論當前使用的是哪一個工具編輯視圖,代碼會保持和這些編輯器展示的樣式一致:

在這里插入圖片描述

② 使用檢查器來定制視圖的顯示樣式

  • 在預覽視圖中,按下 Command 鍵的同時點擊控制元件,會彈出一個編輯彈層,然后選擇檢查器 Inspect, 編輯彈層顯示所有可以定制的視圖屬性,選中的控制元件不同,可以定制的屬性集合也不相同:

在這里插入圖片描述

  • 使用檢查器把文字更改為Turtle Rock,也就是在應用中顯示的第一個地標的名稱:

在這里插入圖片描述

  • 改變字體修改器為 Title,使用系統字體修飾文字,可以自動按照用戶在設備中設定的字體偏好大小進行調整,定制 SwiftUI 視圖所呼叫的方法被稱為視圖修改器 Modifiers,修改器在原視圖的基礎上修改部分顯示樣式和屬性,回傳一個新的視圖,這樣就可以讓多個修改器串連進行,形成水平方向的鏈式呼叫,或者垂直方向的堆疊呼叫:

在這里插入圖片描述

  • 手動在代碼中添加 foregroundColor(.green) 屬性修改器,就會把文字的顏色調整為綠色,代碼是決定視圖樣式的根本,當我們使用檢查器來改變或移除一個屬性修改器時,Xcode 也會在代碼編輯器中同步改變或移除對應的修改器代碼:

在這里插入圖片描述

  • 在代碼編輯器中,按下 Command 的同時點擊 Text 單詞也可以屬性彈窗,從中選擇檢查器后,再點擊 Color 彈出選單,選擇繼承 Inherited,讓文字的顏色恢復成原來的黑色:

在這里插入圖片描述

  • 當我們移除 foregroundColor(.green) 時,Xcode 會自動更新代碼來反映視圖的實際顯示狀況:

在這里插入圖片描述

三、使用堆疊來組合視圖

  • 上文中創建了標題視圖,接下來要添加一些文本視圖來描述地標所在州及所在公園的名稱等其它詳細資訊:

在這里插入圖片描述

  • 創建 SwiftUI 視圖就是在 body 屬性中描述視圖的內容、布局及行為,但 body 屬性只回傳單個視圖,這時組合多個視圖時可以把它們放入一個堆疊中,通過水平、垂直、前后嵌套多個視圖完成視圖組合,做為一個整體在 body 屬性中回傳,
  • 現在使用一個垂直堆疊,把標題放在包含公園詳情的水平堆疊的上方,在水平堆疊中,布局公園詳情相關的內容,可以使用 Xcode 提供的結構化布局來把視圖嵌套在容器視圖中,
  • ① 按下 Command 鍵的同時,點擊 Text 視圖的初始化代碼打開結構化編輯彈窗,然后選擇把控制元件嵌套在垂直堆疊中 Embed in VStack,在堆疊中添加 Text View 控制元件可以從組件中直接拖進堆疊中完成:

在這里插入圖片描述

  • ② 點擊 Xcode 右上角的 + 號,托動一個 Text 控制元件到指定位置,代碼立即就會在編輯器中補全;

在這里插入圖片描述

  • ③ 把 Text 視圖的占位文本修改為 Joshua Tree Nation Park,視圖會自動調整位置布局;
  • ④ 設定位置控制元件的字體為子標題樣式:
struct ContentView: View {
    var body: some View {
        VStack {
            Text("Turtle Rock")
                .font(.title)
            .padding()
            Text("Joshua Tree Nation Park")
                .font(.title2)
        }
    }
}

在這里插入圖片描述

  • ⑤ 設定 VStack 初始化引數為左對齊內部的子視圖,默認情況下,堆疊會把內部視圖在自己的主軸上居中對齊,并自動計算各子視圖的間距,下一步要添加一個 Text 控制用來描述公園的狀態,它水平排列在位置資訊的右邊;

在這里插入圖片描述

  • ⑥ 在畫布內,command 按下的同時點擊位置視圖,在彈出的選單中選擇嵌入到水平堆疊中 Embed in HStack;

在這里插入圖片描述

  • ⑦ 在位置控制元件的后面加一個公園狀態的 Text 視圖,并把占位文字改為 California,字體設定為子標題樣式;

在這里插入圖片描述

  • ⑧ 為了水平布局使用整個螢屏寬度,在位置控制元件和公園狀態控制元件中間添加一個 Spacer 控制元件,用來填充兩個控制元件中間的空白部分,并把兩個控制元件分別頂向螢屏的兩側;Spacer 是一個可以伸縮的空白控制元件,它負責占用其它控制元件布局完成后剩下的所有空間;

在這里插入圖片描述

  • ⑨ 使用 padding() 修改器給地標資訊內容視圖整體加內邊距;

在這里插入圖片描述

四、創建自定義影像視圖 Image

  • 有了地標名稱、地標位置及狀態視圖,下一步再添加一個地標圖片視圖,這個圖片視圖將自定義遮罩 mask、邊框 border 和陰影 shadow;可以從控制元件加中拖一個 Image 到畫布,或直接寫代碼到代碼編輯器中,
  • 在專案資源檔案中找到 turtlerock.png 圖片,把它拖入資源編輯器 asset catalog editor 中,Xcode 會創建一個新的圖片集來存放這個圖片,然后創建一個 SwiftUI 視圖:

在這里插入圖片描述

  • 選擇檔案->新建->檔案,打開模板選擇器,在用戶界面(User Interface)板塊下,選擇 SwiftUI View 并點擊下一步,命名為 CircleImage.swift,并點擊創建(Create),現在已經準備好插入圖片并修改布局來滿足設計目標:

在這里插入圖片描述

  • 用 Image 替換 Text,并使用 turtlerock 圖片初始化 Image 視圖;

在這里插入圖片描述

  • 添加 clipShape(Circle()) 修改器到 Image,給圖片添加圓形剪切效果;Circle 是一個形狀,它可以被用作遮罩、也可以是圓圈,還可以是圓形填充視圖;
  • 創建另一個灰色的圓圈并把它作為一個浮層添加到圖片上,相當于給圖片加了一個灰色邊框;
  • 給視圖添加半徑為 10 的陰影;

在這里插入圖片描述

  • 把圓形邊框的顏色改成白色,就完成了自定義圖片視圖的創建:

在這里插入圖片描述

五、UIKit 視圖與 SwiftUI 視圖混合使用

  • 現在要創建一個地圖視圖,可以使用 MapKit 中的 MKMapView 視圖類來渲染地圖,要在 SwiftUI 中使用 UIView 及其子類,需要把這些 UIView 包裹在一個遵循 UIViewRepresentable 協議的 SwiftUI 視圖中,SwiftUI 中也包含適配 WatchKit 和 AppKit 的類似的協議:

在這里插入圖片描述

  • 創建一個自定義視圖用來容納和顯示 MKMapView:
    • 選擇檔案->新建->檔案,選擇 iOS 平臺,選擇 SwiftUI View 模板,并點擊下一步(Next),命名檔案為 MapView.swift,并點擊創建(Create);
    • 代碼中匯入 MapKit 參考,宣告 MapView 遵循 UIViewRepresentable 協議,UIViewRepresentable 協議要求實作兩個方法 UIView(context:) 和 updateUIView(_:context:),第一個方法用來創建 MKMapView,第二個方法用來配置視圖回應狀態變化;
    • 替換 body,用 makeUIView(context:) 方法來代替,創建并回傳一個空的 MKMapView;
    • 創建方法 updateUIView(_:context:),在方法內部設定地圖視圖的坐標為 Turle Rock 的中心,在靜態模式下預覽時,只會渲染 SwiftUI 視圖的部分,因為 MKMapView 是 UIView 的子類,所以需要切換到實時預覽模式下才能看到地圖被完全渲染出來;

在這里插入圖片描述

    • 點擊 Live Preview(實時預覽)按鈕,可能需要點擊 Try Again 和 Resume 按鈕來激活預覽模式的切換,切換到實時預覽模式下不久就可以看到指定地標所在的地圖位置:

在這里插入圖片描述

六、組合地標詳情頁

  • 我們已經完成了創建一個地標詳情頁所需要的各種子視圖元素:名稱、地點、圓形圖片以及位置地圖,現在可以把這些視圖元素組合在一起形成地標詳情頁的整個視圖:

在這里插入圖片描述

  • 在專案工程瀏覽器中選擇 ContentView.swift 檔案;
  • body 屬性中嵌入一個 VStack 視圖,它內部包含另一個 VStack 視圖,內部的 VStack 視圖又包含三個 Text 視圖;
  • 在外層 VStack 的頂部添加自定義的地圖視圖 MapView,并使用 frame(width:height:) 設定視圖大小,當只指定高度時,寬度會自動計算為父視圖的寬度,在這里就是螢屏寬度;
  • 點擊 Live Preview 按鈕進入實時預覽模式,查看地圖渲染情況,在實時預覽模式下可以編輯視圖,最新的改動也可以實時的重繪出來;
  • 在 MapView 后面再添加一個 CircleImage 視圖;
  • 為了讓圖片視圖疊放在地圖視圖的上面,可以設定圖片視圖的垂直偏移量為 -130,圖片視圖的底部內邊距也為 -130,這個效果就是把圖片垂直上移了 130,同時和下面的文字區域留出了 130 的空白分隔區;
  • 在外層 VStack 內部的最下面加上 Spacer,可以讓上面的視圖內容頂到螢屏的上邊;
  • 為了讓地圖的視圖內容顯示在狀態欄的下方,可以給 MapView 添加 edgesIgnoringSafeArea(.top) 修改器,這可
  • 以讓它在布局時忽略頂部的安全區域邊距;

在這里插入圖片描述

七、總結

  • 在宣告自定義 SwiftUI 視圖時,視圖布局要宣告 body 屬性中;View 協議中要求實作 body 屬性,每一個 SwiftUI 視圖都遵循 View 協議,
  • 有如下代碼布局,那么運行視圖效果是什么樣?
struct ContentView: View {
    var body: some View {
    	CircleImage()
        VStack(alignment: .leading) {
            Text("Turtle Rock")
                .font(.title)
            Text("Joshua Tree Nation Park")
        }
    }
}

在這里插入圖片描述

  • 從 body 屬性中回傳三個視圖:
VStack(alignment: .leading) {
	Text("Turtle Rock")
		.font(.title)
	Divider()
	Text("Joshua Tree Nation Park")
}
  • 修改器每次都是回傳一個新的物件,所以多個修改器可以通過鏈式呼叫,配置視圖時,使用修改器的方式如下:
Text("Turtle Rock")
	.font(.title)
	.foregroundColor(.purple)
  • 完整示例:SwiftUI 之如何創建和組合視圖,

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/385445.html

標籤:其他

上一篇:OpenCV C++案例實戰八《基于Hu矩輪廓匹配》

下一篇:OWOD訓練運行教程

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more