← スキル一覧に戻る

liquid-glass
by aiskillstore
liquid-glassは、other分野における実用的なスキルです。複雑な課題への対応力を強化し、業務効率と成果の質を改善します。
⭐ 102🍴 3📅 2026年1月23日
SKILL.md
name: liquid-glass description: Implement, review, or improve SwiftUI features using the iOS 26+ Liquid Glass API. Use when asked to adopt Liquid Glass in SwiftUI UI, refactor to Liquid Glass, or review Liquid Glass usage.
SwiftUI Liquid Glass
Overview
Liquid Glass is a dynamic material in iOS 26+ that combines optical glass properties with fluidity. It blurs content, reflects surrounding color and light, and reacts to touch interactions in real time.
Workflow Decision Tree
1) Review an existing feature
- Inspect where Liquid Glass should/shouldn't be used
- Verify correct modifier order, shape usage, container placement
- Check for iOS 26+ availability handling and fallbacks
2) Improve a feature using Liquid Glass
- Identify target components (surfaces, chips, buttons, cards)
- Refactor to use
GlassEffectContainerfor multiple glass elements - Add interactive glass only for tappable/focusable elements
3) Implement a new feature using Liquid Glass
- Design glass surfaces and interactions first (shape, prominence, grouping)
- Add glass modifiers after layout/appearance modifiers
- Add morphing transitions only when view hierarchy changes with animation
Core Guidelines
- Prefer native Liquid Glass APIs over custom blurs
- Use
GlassEffectContainerwhen multiple glass elements coexist - Apply
.glassEffect(...)after layout and visual modifiers - Use
.interactive()for elements that respond to touch/pointer - Keep shapes consistent across related elements
- Gate with
#available(iOS 26, *)and provide non-glass fallback
Review Checklist
- Availability:
#available(iOS 26, *)present with fallback UI - Composition: Multiple glass views wrapped in
GlassEffectContainer - Modifier order:
glassEffectapplied after layout/appearance modifiers - Interactivity:
interactive()only where user interaction exists - Transitions:
glassEffectIDused with@Namespacefor morphing - Consistency: Shapes, tinting, and spacing align across feature
Implementation Checklist
- Define target elements and desired glass prominence
- Wrap grouped glass elements in
GlassEffectContainerwith spacing - Use
.glassEffect(.regular.tint(...).interactive(), in: .rect(cornerRadius: ...))as needed - Use
.buttonStyle(.glass)/.buttonStyle(.glassProminent)for actions - Add morphing transitions with
glassEffectIDwhen hierarchy changes - Provide fallback materials for earlier iOS versions
Quick Snippets
Basic Glass Effect with Fallback
if #available(iOS 26, *) {
Text("Hello")
.padding()
.glassEffect(.regular.interactive(), in: .rect(cornerRadius: 16))
} else {
Text("Hello")
.padding()
.background(.ultraThinMaterial, in: RoundedRectangle(cornerRadius: 16))
}
Multiple Glass Elements
GlassEffectContainer(spacing: 24) {
HStack(spacing: 24) {
Image(systemName: "scribble.variable")
.frame(width: 72, height: 72)
.font(.system(size: 32))
.glassEffect()
Image(systemName: "eraser.fill")
.frame(width: 72, height: 72)
.font(.system(size: 32))
.glassEffect()
}
}
Glass Buttons
Button("Confirm") { }
.buttonStyle(.glassProminent)
Button("Cancel") { }
.buttonStyle(.glass)
Morphing Transitions
@State private var isExpanded = false
@Namespace private var namespace
GlassEffectContainer(spacing: 40) {
HStack(spacing: 40) {
Image(systemName: "pencil")
.frame(width: 80, height: 80)
.glassEffect()
.glassEffectID("pencil", in: namespace)
if isExpanded {
Image(systemName: "eraser")
.frame(width: 80, height: 80)
.glassEffect()
.glassEffectID("eraser", in: namespace)
}
}
}
Button("Toggle") {
withAnimation {
isExpanded.toggle()
}
}
.buttonStyle(.glass)
Customizing Glass
Text("Tinted Glass")
.padding()
.glassEffect(.regular.tint(.orange).interactive(), in: .capsule)
Uniting Glass Effects
@Namespace private var namespace
GlassEffectContainer(spacing: 20) {
HStack(spacing: 20) {
ForEach(items.indices, id: \.self) { index in
ItemView(item: items[index])
.glassEffect()
.glassEffectUnion(id: index < 2 ? "group1" : "group2", namespace: namespace)
}
}
}
Shape Options
.capsule(default).rect(cornerRadius: CGFloat).circle
Best Practices
- Container Usage: Always use
GlassEffectContainerfor multiple glass views - Modifier Order: Apply
.glassEffect()after appearance modifiers - Spacing: Choose spacing values carefully to control effect merging
- Animation: Use animations when changing view hierarchies for smooth morphing
- Interactivity: Add
.interactive()only to touchable elements - Consistency: Maintain consistent shapes and styles across your app
スコア
総合スコア
60/100
リポジトリの品質指標に基づく評価
✓SKILL.md
SKILL.mdファイルが含まれている
+20
○LICENSE
ライセンスが設定されている
0/10
○説明文
100文字以上の説明がある
0/10
✓人気
GitHub Stars 100以上
+5
○最近の活動
3ヶ月以内に更新がある
0/10
○フォーク
10回以上フォークされている
0/5
✓Issue管理
オープンIssueが50未満
+5
✓言語
プログラミング言語が設定されている
+5
✓タグ
1つ以上のタグが設定されている
+5
レビュー
💬
レビュー機能は近日公開予定です
