回答:
UIApplicationにあります。
目標Cの場合:
開始:
[UIApplication sharedApplication].networkActivityIndicatorVisible = YES;
終わり:
[UIApplication sharedApplication].networkActivityIndicatorVisible = NO;
迅速:
開始
UIApplication.shared.isNetworkActivityIndicatorVisible = true
終わり
UIApplication.shared.isNetworkActivityIndicatorVisible = false
[[UIApplication sharedApplication] setNetworkActivityIndicatorVisible:YES];
//ワンライナーとして
UIApplication.sharedApplication().networkActivityIndicatorVisible = true
次のマクロはかなり便利です。
#define ShowNetworkActivityIndicator() [UIApplication sharedApplication].networkActivityIndicatorVisible = YES
#define HideNetworkActivityIndicator() [UIApplication sharedApplication].networkActivityIndicatorVisible = NO
したがって、(ヘッダーがもちろん含まれている限り)アプリ内から、ShowNetworkActivityIndicator();
またはHideNetworkActivityIndicator();
アプリ内から呼び出すことができます。
私は何が起こっているかをカウンターに記録することで複数の接続の問題を解決するシングルトンを書きました(接続が戻ったが別の接続がまだアクティブなときにステータスが削除されないようにするため):
ヘッダーファイル:
#import <Foundation/Foundation.h>
@interface RMActivityIndicator : NSObject
-(void)increaseActivity;
-(void)decreaseActivity;
-(void)noActivity;
+(RMActivityIndicator *)sharedManager;
@end
と実装:
#import "RMActivityIndicator.h"
@interface RMActivityIndicator ()
@property(nonatomic,assign) unsigned int activityCounter;
@end
@implementation RMActivityIndicator
- (id)init
{
self = [super init];
if (self) {
self.activityCounter = 0;
}
return self;
}
-(void)increaseActivity{
@synchronized(self) {
self.activityCounter++;
}
[self updateActivity];
}
-(void)decreaseActivity{
@synchronized(self) {
if (self.activityCounter>0) self.activityCounter--;
}
[self updateActivity];
}
-(void)noActivity{
self.activityCounter = 0;
[self updateActivity];
}
-(void)updateActivity{
UIApplication* app = [UIApplication sharedApplication];
app.networkActivityIndicatorVisible = (self.activityCounter>0);
}
#pragma mark -
#pragma mark Singleton instance
+(RMActivityIndicator *)sharedManager {
static dispatch_once_t pred;
static RMActivityIndicator *shared = nil;
dispatch_once(&pred, ^{
shared = [[RMActivityIndicator alloc] init];
});
return shared;
}
@end
例:
[[RMActivityIndicator sharedManager]increaseActivity];
[NSURLConnection sendAsynchronousRequest:urlRequest queue:self.networkReceiveProcessQueue completionHandler:^(NSURLResponse *response, NSData *data, NSError *error)
{
[[RMActivityIndicator sharedManager]decreaseActivity];
}
ネットワークコールが終了した後も、アクティビティインジケーターを非表示にする必要があります。
を使用する場合AFNetworking
、それほど多くのことをする必要はありません。
AppDelegate
クラスで次の変更を行います。
インポート AFNetworking/AFNetworkActivityIndicatorManager.h
これを入れて didFinishLaunchingWithOptions:
[[AFNetworkActivityIndicatorManager sharedManager] setEnabled:YES]
多くの人が言っているように、iPhone Xやおそらく他の新しいiPhone用のネットワークアクティビティインジケーターはありません。
Ortwin Gentz、FutureTapによって作成されたこの素晴らしいライブラリに出くわしました:https : //github.com/futuretap/FTLinearActivityIndicator
それはインジケーターをiPhone Xが最初にリリースされたときの位置に戻します。多くの人はナイトライダータイプのインジケーターを覚えています。
このライブラリはSwift 4.2で利用できるため、ここで説明するようにSwift言語設定を変更する必要があります。 タイプ 'NSAttributedStringKey'(別名 'NSString')にはメンバー 'font'がありません