透過SwiftUI Material 實現Glassmorphism

閱讀時間約 8 分鐘

Glassmorphism設計風格,是從2020就開始流行的UI設計趨勢,概念是Glass(玻璃)和 Skeuomorphism(擬物化)的結合,中文稱為毛玻璃效果。


Table of contents

  • Glassmorphism
  • SwiftUI Material
  • Glassmorphism with SwiftUI Material
  • Conclusion


Glassmorphism

Glassmorphism 讓元素看起來像是透明玻璃一樣,同時保留了一些模糊的背景效果,在介面中創造了一種立體感,可以讓介面元素更加引人注目並增加互動性。Glassmorphism特別強調4個特徵:

  • 透明感/Transparency(背景模糊的磨砂效果)
  • 物件於空間漂浮的多層次感 / Multi-layered approach with objects floating in space
  • 強調模糊透明度的鮮明顏色 / Vivid colors to highlight the blurred transparency
  • 於半透明物件上的細微且光亮的邊框 / A subtle, light border on the translucent objects


利用Glassmorphism可以為UI創造了以下兩種體驗效果:

  1. Focal point:添加這些元素將有助於營造深度感視覺體驗。 這將有助於設計師定義空間並創建焦點。
  2. More visible:透明的佈局幫助APP感覺輕量級,並APP的內容更加可見和有吸引力的。


SwiftUI Material

SwiftUI在iOS 15提供了Material的背景模糊造型效果,可以讓我們簡單達到Glassmorphism的視覺效果。適合應用於背景圖片上的文字說明,疊加背景模糊的色塊以突顯文字。

raw-image

上圖的效果使用ultraThinMaterial最輕微模糊的選項,可惜透明度已經是極限,如果可以更通透會更好。Material提供了5個模糊程度參數,由弱到強為:

  • ultraThinMaterial
  • thinMaterial
  • regularMaterial
  • thickMaterial
  • ultraThickMaterial


Glassmorphism with SwiftUI Material

透過Material的API可以實現Glassmorphism的UI效果,以下是透過SwiftUI實踐的基本步驟:

  1. 建立圓角矩形
  2. 前景使用漸層呈現透明度的漸變
  3. 背景使用Material.ultraThin呈現背景模糊效果
  4. 疊加漸層的外框線,呈現玻璃邊緣反射的效果
  5. 建立陰影呈現漂浮感
let gradientSurface = LinearGradient(colors: [.white.opacity(0.1), .clear], startPoint: .topLeading, endPoint: .bottomTrailing)

RoundedRectangle(cornerRadius: 15, style: .continuous)
    .foregroundStyle(gradientSurface)
    .background(.ultraThinMaterial)
    .overlay(
        RoundedRectangle(cornerRadius: 15, style: .circular)
            .stroke(lineWidth: 1.5)
            .foregroundStyle(gradientBorder)
            .opacity(0.8)
    )
    .shadow(color: .black.opacity(0.25), radius: 5, x: 0, y: 8)


下面示範了五種強度在黑色與白色的效果,可以明顯看出到thickMaterial以上程度的背景過於模糊以至於難以看到背景色塊。

黑色背景中的五種模糊等級

黑色背景中的五種模糊等級

白色背景中的五種模糊等級

白色背景中的五種模糊等級


Glassmorphism UI

接下就透過Material來實作Glassmorphism UI卡片,並在背景加上圓形動畫凸顯毛玻璃的效果。

struct CardView: View {

    let gradientSurface = LinearGradient(colors: [.white.opacity(0.1), .clear], startPoint: .topLeading, endPoint: .bottomTrailing)
    let gradientBorder = LinearGradient(colors: [.white.opacity(0.5), .white.opacity(0.0), .white.opacity(0.0), .green.opacity(0.0), .green.opacity(0.5)], startPoint: .topLeading, endPoint: .bottomTrailing)
    
    var body: some View {
        RoundedRectangle(cornerRadius: 15, style: .continuous)
            .foregroundStyle(gradientSurface)
            .background(.ultraThinMaterial)
            .mask( RoundedRectangle(cornerRadius: 15, style: .circular).foregroundColor(.black) )
            .overlay(
                RoundedRectangle(cornerRadius: 15, style: .circular)
                    .stroke(lineWidth: 1.5)
                    .foregroundStyle(gradientBorder)
                    .opacity(0.8)
            )
            .frame(width: 300, height: 180)
            .shadow(color: .black.opacity(0.25), radius: 5, x: 0, y: 8)
    }
}
  1. 創建RoundedRectangle,作為卡片的主要形狀
  2. 使用foregroundStyle套用gradientSurface的漸層,藉以控制模糊效果的層次變化
  3. 使用background增加ultraThinMaterial的背景模糊效果
  4. 由於ultraThinMaterial會超出RoundedRectangle的圓角邊界,使用mask製作遮罩
  5. 使用overlay套上漸層的邊框,實現Highlight效果
Glassmorphism Card UI

Glassmorphism Card UI

善加利用背景的透明度與模糊效果,將可以創造出視覺的層次感和深度,使介面更具現代感和視覺吸引力。


Design Case

oThings提供色彩主題的設定,在Color theme的選單背景,使用Material.ultraThinMaterial作為填滿效果,通透的效果讓使用者可以即時感受顏色主題的設定結果,然而模糊的背景又不會影響介面資訊的閱讀。

oThings Card UI

oThings Card UI



oThings是Kyle獨立設計與開發的APP, 是一款專為您的生活記憶而設的記憶保存應用程式,讓您專注於記錄珍愛的事物。以SwiftUI介面框架開發,結合設計的創意與程式的創新所創造的混合體驗設計,呈現高質感的動畫轉場與絲滑的互動效果,打造具品牌辨識度的使用體驗。歡迎有興趣的您下載體驗。


Conclusion

在實務設計上應用Glassmorphism,並不代表要整體APP都是毛玻璃的風格,是可以作為局部或者是個別介面元件的簡化應用,讓整體介面呈現一種通透感但資訊又不會背景干擾。透過SwiftUI的Material,讓滿足此介面設計目的之實踐變得相當容易。



avatar-img
2會員
6內容數
在這瞬息萬變的世界中,讓設計師們以混合成長思維的視角思考自身的職涯規劃,以混合體驗設計的觀點思考使用者體驗設計。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
你可能也想看
Google News 追蹤
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
本篇你將學到:「無機」玻璃鏡片(Glass material):冕牌玻璃(Crown)、光致變色鏡片(Photo Chromic Glasses)、高折射率玻璃(High-Index Glasses)。 「有機」樹脂鏡片(Resin Material、碳C):CR39…
Thumbnail
扁平式繪畫風格(Flat Design) 是一種極簡主義的藝術風格,強調使用簡單的幾何形狀和鮮明的色塊來創造圖像。這種風格通常避免使用陰影、漸變和其他三維效果,使畫面看起來平坦而清晰。 特點: 簡單的幾何形狀:使用圓形、方形、三角形等基本形狀來構建圖像。 鮮明的色塊:色彩大膽且飽和,通
在複雜場景中展示文案信息時,為了避免背景元素對信息的干擾,可以採用漸變蒙版方式,增加背景與文案之間的對比效果,使信息更加突出且清晰。同時,蒙版還可以為界面增添層次感,為信息展示創造更好的視覺效果。 選擇合適的蒙版颜色: 蒙版的颜色應該與背景形成鮮明對比,同時也要考慮與文案颜色的搭配,確保文案
Thumbnail
視覺層級並不侷限於平面設計,在用戶體驗及介面上更是一個重要的核心之一。視覺層級除了讓畫面的視覺編排更加精緻好看,更重要的功能是能讓畫面有效地被組織,讓觀者更容易理解。
我自己是希望可以製作iOS app來更好存放我的文章, 更進階一點,可以變成直接錄音後, 照我設定的方式轉換成文檔,讓iPhone變成我更強的助手。 感覺有很多可以探索,用時間慢慢累積經驗。
Thumbnail
本文探討2024年UI/UX設計趨勢,包括深色模式和色彩適應性、微互動和動畫、3D元素與虛擬現實整合,以及以用戶為中心的數據驅動設計、無障礙設計和情感設計的新方法。
Thumbnail
隨著科技的發展,數位設計領域也日益進步,其中「透明度平面化」成為了設計師在處理完稿檔案時必須面對的一大挑戰。在這篇文章中,我們將一探究竟,揭開透明度平面化的神秘面紗,並探討它在當代設計中的重要性,以及如何巧妙應對可能遇到的問題。 透明度平面化 在數位設計的豐富世界裡,透明效果提供了無限的創意
Thumbnail
如水的時光,光 也一樣。
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
本篇你將學到:「無機」玻璃鏡片(Glass material):冕牌玻璃(Crown)、光致變色鏡片(Photo Chromic Glasses)、高折射率玻璃(High-Index Glasses)。 「有機」樹脂鏡片(Resin Material、碳C):CR39…
Thumbnail
扁平式繪畫風格(Flat Design) 是一種極簡主義的藝術風格,強調使用簡單的幾何形狀和鮮明的色塊來創造圖像。這種風格通常避免使用陰影、漸變和其他三維效果,使畫面看起來平坦而清晰。 特點: 簡單的幾何形狀:使用圓形、方形、三角形等基本形狀來構建圖像。 鮮明的色塊:色彩大膽且飽和,通
在複雜場景中展示文案信息時,為了避免背景元素對信息的干擾,可以採用漸變蒙版方式,增加背景與文案之間的對比效果,使信息更加突出且清晰。同時,蒙版還可以為界面增添層次感,為信息展示創造更好的視覺效果。 選擇合適的蒙版颜色: 蒙版的颜色應該與背景形成鮮明對比,同時也要考慮與文案颜色的搭配,確保文案
Thumbnail
視覺層級並不侷限於平面設計,在用戶體驗及介面上更是一個重要的核心之一。視覺層級除了讓畫面的視覺編排更加精緻好看,更重要的功能是能讓畫面有效地被組織,讓觀者更容易理解。
我自己是希望可以製作iOS app來更好存放我的文章, 更進階一點,可以變成直接錄音後, 照我設定的方式轉換成文檔,讓iPhone變成我更強的助手。 感覺有很多可以探索,用時間慢慢累積經驗。
Thumbnail
本文探討2024年UI/UX設計趨勢,包括深色模式和色彩適應性、微互動和動畫、3D元素與虛擬現實整合,以及以用戶為中心的數據驅動設計、無障礙設計和情感設計的新方法。
Thumbnail
隨著科技的發展,數位設計領域也日益進步,其中「透明度平面化」成為了設計師在處理完稿檔案時必須面對的一大挑戰。在這篇文章中,我們將一探究竟,揭開透明度平面化的神秘面紗,並探討它在當代設計中的重要性,以及如何巧妙應對可能遇到的問題。 透明度平面化 在數位設計的豐富世界裡,透明效果提供了無限的創意
Thumbnail
如水的時光,光 也一樣。