swift UIView的+ ActivityIndicator.swift
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了swift UIView的+ ActivityIndicator.swift相关的知识,希望对你有一定的参考价值。
//
// UIViewController+ActivityIndicator.swift
// RTA
//
// Created by Joel Arcos on 3/5/19.
// Copyright © 2019 Albert Gedeon. All rights reserved.
//
import UIKit
var overallView: UIView = UIView()
var activityIndicatorOverlay: UIView = UIView()
var activityIndicator: UIActivityIndicatorView = UIActivityIndicatorView()
var totalAdjustment: CGFloat?
// =================================================================================================
// API
// =================================================================================================
extension UIViewController {
func showActivityIndicatorOverlay() {
setupOverlay()
setupActivityIndicatorOverlay()
setupActivityIndicator()
stackViews()
activityIndicator.startAnimating()
}
// remove activity indicator from this view
func hideActivityIndicatorOverlay() {
activityIndicator.stopAnimating()
overallView.removeFromSuperview()
}
}
// =================================================================================================
// Internal Methods
// ================================================================================================
extension UIViewController {
struct Colors {
static let white = UIColorFromHex(rgbValue: 0xffffff, alpha: 0.3)
static let dark = UIColorFromHex(rgbValue: 0x444444, alpha: 0.7)
}
private func setupOverlay() {
overallView.frame = self.view.frame
let navBarHeight = makeHeightAdjustmentForNavBar()
let safeAreaHeight = makeHeightAdjustmentForSafeAreaPadding()
totalAdjustment = navBarHeight + safeAreaHeight
overallView.center = CGPoint(x: self.view.center.x, y: self.view.center.y - (totalAdjustment ?? 0))
overallView.backgroundColor = Colors.dark
}
private func makeHeightAdjustmentForNavBar() -> CGFloat {
var frameHeight: CGFloat = 0.0
if let rootVC = UIApplication.shared.keyWindow!.rootViewController {
frameHeight = rootVC.view.frame.height
if rootVC is UINavigationController {
let navController = rootVC as! UINavigationController
frameHeight = navController.navigationBar.frame.height
}
}
return frameHeight
}
private func makeHeightAdjustmentForSafeAreaPadding() -> CGFloat {
var frameHeight: CGFloat = 0.0
let topPadding = UIApplication.shared.keyWindow!.safeAreaInsets.top
frameHeight = frameHeight + topPadding
return frameHeight
}
private func setupActivityIndicatorOverlay() {
activityIndicatorOverlay.frame = CGRect.init(x: 0, y: 0, width: 80, height: 80)
activityIndicatorOverlay.center = CGPoint(x: self.view.center.x, y: self.view.center.y - (totalAdjustment ?? 0))
activityIndicatorOverlay.backgroundColor = Colors.white
activityIndicatorOverlay.clipsToBounds = true
activityIndicatorOverlay.layer.cornerRadius = 10
}
private func setupActivityIndicator() {
activityIndicator.frame = CGRect.init(x: 0.0, y: 0.0, width: 40.0, height: 40.0)
activityIndicator.style = UIActivityIndicatorView.Style.whiteLarge
activityIndicator.center = CGPoint.init(x: activityIndicatorOverlay.frame.size.width / 2, y: activityIndicatorOverlay.frame.size.height / 2)
}
private func stackViews() {
activityIndicatorOverlay.addSubview(activityIndicator)
overallView.addSubview(activityIndicatorOverlay)
self.view.addSubview(overallView)
}
//Define UIColor from hex value
private static func UIColorFromHex(rgbValue:UInt32, alpha:Double=1.0)->UIColor {
let red = CGFloat((rgbValue & 0xFF0000) >> 16)/256.0
let green = CGFloat((rgbValue & 0xFF00) >> 8)/256.0
let blue = CGFloat(rgbValue & 0xFF)/256.0
return UIColor(red:red, green:green, blue:blue, alpha:CGFloat(alpha))
}
}
以上是关于swift UIView的+ ActivityIndicator.swift的主要内容,如果未能解决你的问题,请参考以下文章
Swift:在另一个 UIView 下的 UIView 的 hitTest
如果 Swift 通过值而不是引用传递,为啥我可以通过将 UIView 传递给函数来在 Swift 中操作 UIView 的属性? [复制]
将 UIView 作为 SubView 添加到自定义类、UIView 的子类、Swift