Media is too big
VIEW IN TELEGRAM
Предлагаю полюбоваться на этот прекрасный и очень простой в реализации эффект, который был в уроке
https://www.hackingwithswift.com/books/ios-swiftui/scrollview-effects-using-geometryreader
#hackingwithswift
https://www.hackingwithswift.com/books/ios-swiftui/scrollview-effects-using-geometryreader
#hackingwithswift
🔥2
Проект 18 (день 94)
Заключительная часть Проекта 18 включает:
🔴 Тест - результаты которого можно найти в предыдущем посте https://t.me/c/2294310025/234
🔴 Челленж - видео будет в следующем посте. В основу взят список с различными (фиксированными цветами).
Челенж небольшой, всего 3 задания:
🟢 эффект прозрачности для элементов сверху списка
🟢 масштабирование - сверху элементы меньше размером, внизу больше
🟢 менять цвета в зависимости от положения на экране, но я также добавил изменение цвета ещё и в зависимости от индекса
#hackingwithswift
Заключительная часть Проекта 18 включает:
Челенж небольшой, всего 3 задания:
#hackingwithswift
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥1
День 95 - Челенж
❗️ Предлагается создать приложения для броска кубика (1, 2 или 3).
Что ж, оказалось сделать это не просто😰 И признаться я с этим не справился. Хотя потратил на это больше одного дня, с перерывами, но всё же.
Изначально я хотел сделать зацикленный прокручивающийся список. ScrollView для этого не подходит, да и в целом, у SwiftUI нет подходящей реализации, и нужно делать её самостоятельно.
Попытка сделать VStack со сдвигами элементов не увенчалась успехом и мне пришла идея сделать вращающиеся барабаны как в автоматах казино. Для этого я использовал уже знакомый
Результат далёк от идеала, увидеть это можно на видео.
1️⃣ Полупрозрачность даёт не тот результат, который я ожидал. Особенно при анимировании, вращение прозрачных чисел выглядит как пробел в “барабане”
2️⃣ Для большого количества граней числа наезжают друг на друга. Как увеличить между ними размер я не придумал.
3️⃣ Добавление нового “кубика” может создать его в невалидном состоянии.
#hackingwithswift
Что ж, оказалось сделать это не просто
Изначально я хотел сделать зацикленный прокручивающийся список. ScrollView для этого не подходит, да и в целом, у SwiftUI нет подходящей реализации, и нужно делать её самостоятельно.
Попытка сделать VStack со сдвигами элементов не увенчалась успехом и мне пришла идея сделать вращающиеся барабаны как в автоматах казино. Для этого я использовал уже знакомый
rotation3DEffect
.Результат далёк от идеала, увидеть это можно на видео.
#hackingwithswift
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1👏1🤔1
Проект 19 (день 96). Подготовка к написанию приложения для поиска лыжных курортов.
🔴 🔥
🔴
🔴
🔴 Поиск по вьюхе! Просто добавляем
🔴
Выглядит как глобальные переменные, которые с пелёнок учат не использовать. На бэкэнде с этим хорошо справляется Dependency Injection.
#hackingwithswift
NavigationSplitView
- знакомимся с нюансами разработки под iPad, но очень поверхностно. Рассматривали как можно оптимальнее использовать большой экран. Единая кодовая база - alert()
& sheet()
можно использовать с опциональными значениями.
Button(“Кликай”) {
selectedUser = User()
}
.sheet(item: $selectedUser) { user in
Text(user.id)
}
Group
- view, как следует из названия, для группировки, без влияния на layout. Parent будет ответственным за отображение (вертикально, горизонтально, или по z оси). Можно задавать один стиль для набора вьюшек..searchable
модификатор и появляется search bar
struct ContentView: View {
@State private var searchText = ""
var body: some View {
NavigationStack {
Text("Searching for \(searchText)")
.searchable(text: $searchText, prompt: “Найдём что-нибудь?”)
.navigationTitle("Searching")
}
}
}
@Observable
как Environment элемент. Если не хочется передавать объект во вложенные вьюхи через конструктор (придется передать в каждую вью в иерархии), можно положить в .environment
.Выглядит как глобальные переменные, которые с пелёнок учат не использовать. На бэкэнде с этим хорошо справляется Dependency Injection.
#hackingwithswift
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1
This media is not supported in your browser
VIEW IN TELEGRAM
Проект 19 (день 97 и день 98)
Решил объединить оба дня в один пост, так как тут сильно нечего рассказывать. Мы сделали приложение, используя подходы из предыдущего урока. Впереди нас ждёт небольшой челленж.
Это было последнее приложение, и, к сожалению, мы не применили большинство изученных инструментов.
#hackingwithswift
Решил объединить оба дня в один пост, так как тут сильно нечего рассказывать. Мы сделали приложение, используя подходы из предыдущего урока. Впереди нас ждёт небольшой челленж.
Это было последнее приложение, и, к сожалению, мы не применили большинство изученных инструментов.
#hackingwithswift
👍1
Проект 19 (день 99)
Челенж оказался не очень сложным:
🔴 Сортировка по id, имени и стране
🔴 Имя автора на фото
🔴 Сохранение и чтение используя UserDefaults
Самое интересное было в сортировке. Поскольку все поля (id, name, country) имеют одинаковый тип String, я подумал что было бы круто использовать
#hackingwithswift
Челенж оказался не очень сложным:
Самое интересное было в сортировке. Поскольку все поля (id, name, country) имеют одинаковый тип String, я подумал что было бы круто использовать
KeyPath
. Добавил его везде где нужно и прокинул в метод сортировки. Но разочарование не заставило себя долго ждать. Оказывается Picker
не умеет работать с такими типами (или я 🤭). Пришлось добавить enum.#hackingwithswift
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥2
Всем привет! 👋
Думаю, настало время дать оценку 100-дневному курсу по SwiftUI от hackingwithswift.
https://www.hackingwithswift.com/100/swiftui
🔸 Общее впечатление: 5/5
Мне определенно заходит такой формат. Отличное сочетание теории, самостоятельной работы и тестов для самопроверки.
🔸 Понятность материала: 4/5
В целом почти все темы понятны, но после прохождения курса ощущается наличие некоторых пробелов.
🔸 Подача: 5/5
Формат видео удачно построен, живое общение Пола приятно смотреть. За дублирование темы в виде текста отдельный плюс.
🔸 Полезность: 5/5
Открыл для себя разработку UI приложений. Пришло понимание как это работает на самом базовом уровне.
#hackingwithswift
Думаю, настало время дать оценку 100-дневному курсу по SwiftUI от hackingwithswift.
https://www.hackingwithswift.com/100/swiftui
Мне определенно заходит такой формат. Отличное сочетание теории, самостоятельной работы и тестов для самопроверки.
В целом почти все темы понятны, но после прохождения курса ощущается наличие некоторых пробелов.
Формат видео удачно построен, живое общение Пола приятно смотреть. За дублирование темы в виде текста отдельный плюс.
Открыл для себя разработку UI приложений. Пришло понимание как это работает на самом базовом уровне.
#hackingwithswift
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥2