日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

SwiftUI 使用 visualEffect 視圖修飾符

來源: 責編: 時間:2024-01-02 09:31:29 207觀看
導讀前言在 WWDC 23 中,SwiftUI 引入了一個名為 visualEffect 的新視圖修飾符。此修飾符允許我們通過訪問特定視圖的布局信息來附加一組可動畫化的視覺效果。下面我們將學習如何在 SwiftUI 中使用新的 visualEffect 視圖修

前言

在 WWDC 23 中,SwiftUI 引入了一個名為 visualEffect 的新視圖修飾符。此修飾符允許我們通過訪問特定視圖的布局信息來附加一組可動畫化的視覺效果。下面我們將學習如何在 SwiftUI 中使用新的 visualEffect 視圖修飾符。DwL28資訊網——每日最新資訊28at.com

介紹 visualEffect

讓我們從使用 visualEffect 視圖修飾符的最簡單示例開始。DwL28資訊網——每日最新資訊28at.com

struct ContentView: View {    var body: some View {        Text("Hello World!")            .visualEffect { initial, geometry in                initial.offset(geometry.size)            }    }}

正如你在上面的示例中所看到的,我們定義了一個文本視圖并附加了 visualEffect 視圖修飾符。每當你附加 visualEffect 視圖修飾符時,你應該指定效果閉包。這是你應用所有需要的效果的地方。DwL28資訊網——每日最新資訊28at.com

效果閉包為你提供了兩個參數。第一個是附加到視圖的效果集合的初始狀態。它是 EmptyVisualEffect 類型的實例。我們使用此實例來附加額外的效果。第二個參數是包含視圖的所有布局信息的 GeometryProxy 類型的實例,比如 frame、安全區域等。DwL28資訊網——每日最新資訊28at.com

什么是視覺效果?

視覺效果是可以改變視圖的視覺外觀但不影響其布局的任何東西。在 SwiftUI 框架的先前版本中,我們有視圖修飾符,如縮放、偏移、模糊、對比度、飽和度、不透明度、旋轉等。它們全部都是視覺效果,并且現在符合 VisualEffect 協議。你可以在 visualEffect 閉包中使用其中任何一個。DwL28資訊網——每日最新資訊28at.com

struct ContentView: View {        var body: some View {        Text("Hello World!")            .visualEffect { initial, geometry in                initial                    .blur(radius: 8)                    .opacity(0.9)                    .scaleEffect(.init(width: 2, height: 2))            }    }}

像 frame 和 padding 這樣的東西不是視覺效果,你不能在 visualEffect 閉包中使用它們,因為它們修改了視圖層次結構的布局。DwL28資訊網——每日最新資訊28at.com

visualEffect 修飾符視覺效果

visualEffect 視圖修飾符是完成舊事物的新方法。我們可以使用舊視圖修飾符修改視圖的不透明度和偏移。如果你不需要布局信息,你可以繼續使用它們。新方法的唯一區別是我們通過從 GeometryProxy 提供的布局信息計算視圖的視覺效果的方式來限定視圖的視覺效果。DwL28資訊網——每日最新資訊28at.com

visualEffect 視圖修飾符支持可動畫化的值。因此,你可以繼續使用它根據視圖在視圖層次結構中的框架和邊界來動畫化視圖的視覺外觀。DwL28資訊網——每日最新資訊28at.com

struct ContentView: View {    @State private var isScaled = false        var body: some View {        VStack {            Button("Scale") {                isScaled.toggle()            }                        Text("Hello World!")                .visualEffect { initial, geometry in                    initial.scaleEffect(                        CGSize(                            width: isScaled ? 2 : 1,                            height: isScaled ? 2 : 1                        )                    )                }                .animation(.smooth, value: isScaled)        }    }}

完整的代碼

import SwiftUIstruct ContentView: View {    var body: some View {        Text("Hello World!")            .visualEffect { initial, geometry in                initial.offset(geometry.size)            }    }}struct ContentViewWithEffects: View {    var body: some View {        Text("Hello World!")            .visualEffect { initial, geometry in                initial                    .blur(radius: 8)                    .opacity(0.9)                    .scaleEffect(.init(width: 2, height: 2))            }    }}struct ContentViewWithAnimation: View {    @State private var isScaled = false        var body: some View {        VStack {            Button("Scale") {                isScaled.toggle()            }                        Text("Hello World!")                .visualEffect { initial, geometry in                    initial.scaleEffect(                        CGSize(                            width: isScaled ? 2 : 1,                            height: isScaled ? 2 : 1                        )                    )                }                .animation(.smooth, value: isScaled)        }    }}struct ContentView_Previews: PreviewProvider {    static var previews: some View {        ContentView()        ContentViewWithEffects()        ContentViewWithAnimation()    }}

將上述代碼放入 Swift 文件中,然后在 Xcode 中打開并運行,選擇合適的模擬器。請注意,由于視覺效果和動畫效果,最好在模擬器上查看效果。DwL28資訊網——每日最新資訊28at.com

總結

本文章介紹了在 SwiftUI 中引入的新視圖修飾符 visualEffect。該修飾符允許我們通過訪問特定視圖的布局信息來附加一組可動畫的視覺效果。給出了一些使用 visualEffect 的簡單示例,包括如何使用效果閉包以及如何應用一些常見的視覺效果(例如模糊、透明度、縮放)。DwL28資訊網——每日最新資訊28at.com

此外,還提到了 GeometryProxy 類型的使用,以及 visualEffect 對可動畫值的支持,使得可以根據視圖的幀和邊界來動態調整視覺外觀。DwL28資訊網——每日最新資訊28at.com

最后,指出了 visualEffect 修飾符在向后兼容性方面的注意事項,并建議在不需要布局信息的情況下繼續使用傳統的視圖修飾符。DwL28資訊網——每日最新資訊28at.com

DwL28資訊網——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-55247-0.htmlSwiftUI 使用 visualEffect 視圖修飾符

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 收藏,前端開發必備的文件處理庫!

下一篇: SwiftUI 使用 visualEffect 視圖修飾符

標簽:
  • 熱門焦點
  • CSS單標簽實現轉轉logo

    轉轉品牌升級后更新了全新的Logo,今天我們用純CSS來實現轉轉的新Logo,為了有一定的挑戰性,這里我們只使用一個標簽實現,將最大化的使用CSS能力完成Logo的繪制與動畫效果。新logo
  • 企業采用CRM系統的11個好處

    客戶關系管理(CRM)軟件可以為企業提供很多的好處,從客戶保留到提高生產力。  CRM軟件用于企業收集客戶互動,以改善客戶體驗和滿意度。  CRM軟件市場規模如今超過580
  • 這款新興工具平臺,讓你的電腦效率翻倍

    隨著信息技術的發展,我們獲取信息的渠道越來越多,但是處理信息的效率卻成為一個瓶頸。于是各種工具應運而生,都在爭相解決我們的工作效率問題。今天我要給大家介紹一款效率
  • 虛擬鍵盤 API 的妙用

    你是否在遇到過這樣的問題:移動設備上有一個固定元素,當激活虛擬鍵盤時,該元素被隱藏在了鍵盤下方?多年來,這一直是 Web 上的默認行為,在本文中,我們將探討這個問題、為什么會發生
  • 為什么你不應該使用Div作為可點擊元素

    按鈕是為任何網絡應用程序提供交互性的最常見方式。但我們經常傾向于使用其他HTML元素,如 div span 等作為 clickable 元素。但通過這樣做,我們錯過了許多內置瀏覽器的功能。
  • 網紅炒股不為了賺錢,那就是耍流氓!

    來源:首席商業評論6月26日高調宣布入市,網絡名嘴大v胡錫進居然進軍了股市。在一次財經媒體峰會上,幾個財經圈媒體大佬就“胡錫進炒股是否知道認真報道”展開討論。有
  • 3699元!iQOO Neo8 Pro頂配版今日首銷:1TB UFS 4.0同價位唯一

    5月23日,iQOO推出了全新的iQOO Neo8系列,包含iQOO Neo8和iQOO Neo8 Pro兩個版本,其中標準版搭載高通驍龍8+,而Pro版更是首發搭載了聯發科天璣9200+旗艦
  • 到手價3099元起!iQOO Neo8 Pro今日首銷:安卓性能最強旗艦

    5月23日,iQOO如期舉行了新品發布會,全新的iQOO Neo8系列也正式與大家見面,包含iQOO Neo8和iQOO Neo8 Pro兩個版本,其中標準版搭載高通驍龍8+,而Pro版更
  • 聯想小新Pad Pro 12.6將要推出,搭載高通驍龍 870 處理器

    聯想小新Pad Pro 12.6將于秋季新品會上推出,官方按照慣例直接在發布會前給出了機型的所有參數。聯想小新 Pad Pro 12.6 將搭載高通驍龍 870 處理器,重量為 5
Top 主站蜘蛛池模板: 福安市| 武义县| 岱山县| 林周县| 平罗县| 沙湾县| 平泉县| 泸定县| 长岛县| 方正县| 营口市| 宣汉县| 宝坻区| 高州市| 曲麻莱县| 翁源县| 南昌市| 梅州市| 镇康县| 文安县| 海阳市| 淮北市| 福建省| 安丘市| 兴和县| 宁化县| 白城市| 舒兰市| 西华县| 忻城县| 那曲县| 东平县| 辽阳市| 丰台区| 开阳县| 和平县| 新闻| 那坡县| 北辰区| 南安市| 仁寿县|