Swift:在自定义类中启动和停止活动指示器的动画

Tom*_*Fox 1 uiactivityindicatorview ios swift

我想将活动指示器放在自定义类中,以便可以从任何视图控制器启动/停止它。

以下代码在启动活动指示器但不停止时有效,我该怎么做?

static func activityIndicatorFunction(view: UIView, targetVC: UIViewController, animate: Bool) {

    var activityIndicator: UIActivityIndicatorView = UIActivityIndicatorView()

    if animate == false {
        activityIndicator.stopAnimating()
        UIApplication.shared.endIgnoringInteractionEvents()
    } else {
        activityIndicator = UIActivityIndicatorView(frame: CGRect(x: 0, y: 0, width: 100, height: 100))
        activityIndicator.backgroundColor = UIColor(red:0.16, green:0.17, blue:0.21, alpha:1)
        activityIndicator.layer.cornerRadius = 6
        activityIndicator.center = targetVC.view.center
        activityIndicator.hidesWhenStopped = true
        activityIndicator.activityIndicatorViewStyle = UIActivityIndicatorViewStyle.whiteLarge
        view.addSubview(activityIndicator)
        activityIndicator.startAnimating()
        //UIApplication.shared.beginIgnoringInteractionEvents()
    }
}
Run Code Online (Sandbox Code Playgroud)

启动活动指示器的示例,如果我想停止它,则animate参数将为false。

Utils.activityIndicatorFunction(view: view, targetVC: self, animate: true)
Run Code Online (Sandbox Code Playgroud)

Gui*_*rez 5

这是协议扩展的理想选择。我最近自己做了这个。

首先在文件中创建协议,例如ActivityIndi​​catorPresenter.swift

/// Used for ViewControllers that need to present an activity indicator when loading data.
public protocol ActivityIndicatorPresenter {

    /// The activity indicator
    var activityIndicator: UIActivityIndicatorView { get }

    /// Show the activity indicator in the view
    func showActivityIndicator()

    /// Hide the activity indicator in the view
    func hideActivityIndicator()
}
Run Code Online (Sandbox Code Playgroud)

创建协议扩展名(在同一文件中或在另一个文件中)

public extension ActivityIndicatorPresenter where Self: UIViewController {

    func showActivityIndicator() {
        DispatchQueue.main.async {

            self.activityIndicator.activityIndicatorViewStyle = .whiteLarge
            self.activityIndicator.frame = CGRect(x: 0, y: 0, width: 80, height: 80) //or whatever size you would like
            self.activityIndicator.center = CGPoint(x: self.view.bounds.size.width / 2, y: self.view.bounds.height / 2)
            self.view.addSubview(self.activityIndicator)
            self.activityIndicator.startAnimating()
        }
    }

    func hideActivityIndicator() {
        DispatchQueue.main.async {
            self.activityIndicator.stopAnimating()
            self.activityIndicator.removeFromSuperview()
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

然后,任何视图控制器都可以遵守协议

class MyViewController: UIViewController, ActivityIndicatorPresenter {

/// Make sure to add the activity indicator
var activityIndicator = UIActivityIndicatorView()

//Suppose you want to load some data from the network in this view controller
override func viewDidLoad() {
    super.viewDidLoad()
    showActivityIndicator() //Wow you can use this here!!!
    getSomeData { data in 
        //do stuff with data
        self.hideActivityIndicator()
    }
}
Run Code Online (Sandbox Code Playgroud)