2016-06-13 4 views
0

В моем приложении я использую пользовательский вид UIActivityIndicator (this), и он отлично работает. У меня есть UITableView, и я хочу, чтобы индикатор над табличным представлением загружал данные. Чтобы решить проблему, я создал пустой вид с фоном, прежде всего, и когда мне нужно запустить анимацию индикатора, я просто скрываю представление таблицы и показываю пустой вид + индикатор.Диалоговое окно UIActivityIndicatorView

Результат таков:

Image 1

я где-то видел, что я могу использовать вместо этого что-то вроде этого:

Image 2

Как я могу сделать?

Заранее спасибо.

+0

Вы имеете в виду тусклый фон? –

+0

Не будет 'NVActivityIndicatorViewable' работать для вас? – srvv

+0

@SonLe да, я думаю, что это то, что я ищу – Jigen

ответ

1

Вы можете попробовать добавить полупрозрачный черный вид в виде таблицы и поместить код индикатора пользовательского действия в качестве подзона в режиме «Черный».

let aBlackView = UIView(frame: CGRectMake(0, 0, self.view.bounds.width, self.view.bounds.height)) 
aBlackView.backgroundColor = UIColor.blackColor() 
aBlackView.alpha = 0.75 // Change the alpha depending on how much transparency you require 

let aMainWindow = UIApplication.sharedApplication().delegate!.window 
aMainWindow!!.addSubview(aBlackView) 

/* Enter you code for NVActivityIndicatorViewable here */ 

aBlackView.addSubview(/* NVActivityIndicatorViewable */) 

После того, как вы закончите с вашим запросом, вы можете удалить черный вид, вызвав этот код:

aBlackView.removeFromSuperview() 
1

Я создал деятельность, показывая экран. Я использовал все в моем проекте.

//ProgressBarNotification.swift

import Foundation 
import UIKit 

class ProgressBarNotification { 

internal static var strLabel = UILabel() 
internal static var messageFrame = UIView() 
internal static var activityIndicator = UIActivityIndicatorView()  

internal static func progressBarDisplayer(msg:String,indicator:Bool){ 


    let view1 = UIApplication.sharedApplication().delegate?.window!!.rootViewController?.view 

    view1?.userInteractionEnabled = false 

    strLabel = UILabel(frame: CGRect(x: 50, y: 0, width: 200, height: 50)) 
    strLabel.text = msg 
    strLabel.textColor = UIColor.whiteColor() 
    messageFrame = UIView(frame: CGRect(x: view1!.frame.midX - 90, y: view1!.frame.midY - 25 , width: 180, height: 50)) 
    messageFrame.layer.cornerRadius = 15 
    messageFrame.backgroundColor = UIColor(white: 0, alpha: 0.7) 
    if indicator { 
     activityIndicator = UIActivityIndicatorView(activityIndicatorStyle: UIActivityIndicatorViewStyle.White) 
     activityIndicator.frame = CGRect(x: 0, y: 0, width: 50, height: 50) 
     activityIndicator.startAnimating() 
     messageFrame.addSubview(activityIndicator) 
    } 
    messageFrame.addSubview(strLabel) 
    view1!.addSubview(messageFrame) 


} 

internal static func removeProgressBar() { 

    let view1 = UIApplication.sharedApplication().delegate?.window!!.rootViewController?.view 

    _ = view1?.subviews.filter({ (view) -> Bool in 
     if view == ProgressBarNotification.messageFrame { 
      view.removeFromSuperview() 
     } 
     return false 
    }) 

    ProgressBarNotification.messageFrame.removeFromSuperview() 

    view1?.userInteractionEnabled = true 

} 

    deinit{ 

    } 
} 

Использование

//To start Loader 

    ProgressBarNotification.progressBarDisplayer("Loading", indicator: true) 

    //Stop 

    ProgressBarNotification.removeProgressBar() 
Смежные вопросы