Добавить анимацию в UIview, созданный программно

Я пытаюсь создать UILabel.

Но я хочу анимировать, когда появляется этот ярлык

где я должен анимировать ярлык ??

Вот мой код

static func setupView(view: UIView){
       let networkStatusView = UILabel(frame: CGRect(x: 0, y: 40, width: view.bounds.width, height:50))
        networkStatusView.tag = 20
        networkStatusView.text = "offline"
        networkStatusView.font = UIFont.boldSystemFont(ofSize: 18)
        networkStatusView.translatesAutoresizingMaskIntoConstraints = false
        networkStatusView.textAlignment = .center
        networkStatusView.backgroundColor=UIColor.green
        networkStatusView.layer.borderColor = UIColor.white.cgColor

        UIView.animate(withDuration: 0.5) {
        view.addSubview(networkStatusView)
        }
        view.layoutIfNeeded()    
    }
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
0
729
3

Ответы 3

Функция addSubview не анимируется. Предполагая, что вам нужен эффект затухания, вы должны изменить последние 4 строки на:

view.addSubview(networkStatusView)
networkStatusView.alpha = 0.0
UIView.animate(withDuration: 0.5) {
    networkStatusView.alpha = 1.0
    view.layoutIfNeeded()
}

Надеюсь это поможет

Я проголосовал, но установка alpha относится к анимированному закрытию. Однако layoutIfNeeded этого не делает. Предположительно, он хочет скрыть его alpha, но не анимировать его до конечного местоположения.

Rob 11.02.2019 18:11

Просто чтобы это было похоже на падение с вершины

Дайте начальную высоту для просмотра: 0

и анимировать его как:

view.addSubview(networkStatusView)
    UIView.animate(withDuration: 0.5) {
         networkStatusView.frame.size.height = 50
        view.layoutIfNeeded()
    }

Чтобы помочь визуализировать, как работает UIView.animate;

Подумайте о состоянии вашего UILabel перед вызовом метода UIView.animate. Например, на основе ответ qtngonetworkStatusView будет подвидом для текущего представления ViewController и не будет виден, так как альфа установлена ​​на 0.

Теперь с анимационным блоком:

UIView.animate(withDuration: 0.5) { networkStatusView.alpha = 1.0 view.layoutIfNeeded() }

Разработчик говорит системе анимировать networkStatusView в течение следующих 0,5 секунд и изменить альфа-канал представления с 0 на 1,0, что делает его видимым.

Надеюсь это поможет.

Другие вопросы по теме