Я использую следующий код, это работает совершенно нормально, но его полный экран, однако в случае анимации App Store, его не полноэкранного представления. Я также пробовал поп -просмотр и пользовательский вид, но не работал. < /P>
struct ContentView: View {
let icons = [
Icon(id: "figure.badminton", color: .red),
Icon(id: "figure.fencing", color: .orange),
Icon(id: "figure.gymnastics", color: .green),
Icon(id: "figure.indoor.cycle", color: .blue),
Icon(id: "figure.outdoor.cycle", color: .purple),
Icon(id: "figure.rower", color: .indigo),
]
@Namespace var animation
@State private var selected: Icon?
var body: some View {
ZStack {
LazyVGrid(columns: [.init(.adaptive(minimum: 100, maximum: 300))]) {
ForEach(icons) { icon in
Button {
selected = icon
} label: {
Image(systemName: icon.id)
}
.foregroundStyle(icon.color.gradient)
.font(.system(size: 100))
.background(Color.yellow.opacity(0.5))
.matchedTransitionSource(id: icon.id, in: animation)
}
}
.sheet(item: $selected, content: { icon in
VStack(content: {
DestinationView(icon: icon, animation: animation)
.background(Color.yellow.opacity(0.5))
.presentationDetents([.medium])
})
})
.background(Color.yellow.opacity(0.5))
}
.background(.yellow)
.ignoresSafeArea(.all)
}
}
< /code>
Представлено представление, это < /p>
struct DestinationView: View {
var icon: Icon
var animation: Namespace.ID
var body: some View {
Image(systemName: icon.id)
.font(.system(size: 200))
.frame(width: 250, height: 250)
.foregroundStyle(icon.color.gradient)
.background(Color.yellow.opacity(0.5))
.navigationTransition(.zoom(sourceID: icon.id, in: animation))
}
}
Подробнее здесь: https://stackoverflow.com/questions/797 ... ature-view
Как достичь анимации, похожая на представление о функциях App Store ⇐ IOS
Программируем под IOS
-
Anonymous
1756992783
Anonymous
Я использую следующий код, это работает совершенно нормально, но его полный экран, однако в случае анимации App Store, его не полноэкранного представления. Я также пробовал поп -просмотр и пользовательский вид, но не работал. < /P>
struct ContentView: View {
let icons = [
Icon(id: "figure.badminton", color: .red),
Icon(id: "figure.fencing", color: .orange),
Icon(id: "figure.gymnastics", color: .green),
Icon(id: "figure.indoor.cycle", color: .blue),
Icon(id: "figure.outdoor.cycle", color: .purple),
Icon(id: "figure.rower", color: .indigo),
]
@Namespace var animation
@State private var selected: Icon?
var body: some View {
ZStack {
LazyVGrid(columns: [.init(.adaptive(minimum: 100, maximum: 300))]) {
ForEach(icons) { icon in
Button {
selected = icon
} label: {
Image(systemName: icon.id)
}
.foregroundStyle(icon.color.gradient)
.font(.system(size: 100))
.background(Color.yellow.opacity(0.5))
.matchedTransitionSource(id: icon.id, in: animation)
}
}
.sheet(item: $selected, content: { icon in
VStack(content: {
DestinationView(icon: icon, animation: animation)
.background(Color.yellow.opacity(0.5))
.presentationDetents([.medium])
})
})
.background(Color.yellow.opacity(0.5))
}
.background(.yellow)
.ignoresSafeArea(.all)
}
}
< /code>
Представлено представление, это < /p>
struct DestinationView: View {
var icon: Icon
var animation: Namespace.ID
var body: some View {
Image(systemName: icon.id)
.font(.system(size: 200))
.frame(width: 250, height: 250)
.foregroundStyle(icon.color.gradient)
.background(Color.yellow.opacity(0.5))
.navigationTransition(.zoom(sourceID: icon.id, in: animation))
}
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79755297/how-to-achieve-animation-similar-to-app-stores-feature-view[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия