欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟定位、是否允許消息推送等權(quán)限的實(shí)例

 更新時(shí)間:2018年01月11日 10:10:29   作者:夕陽(yáng)下的守望者  
下面小編就為大家分享一篇iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟定位、是否允許消息推送等權(quán)限的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

1.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟定位:

需要導(dǎo)入:

#import <CoreLocation/CoreLocation.h> 

代碼如下:

+ (void)openLocationServiceWithBlock:(ReturnBlock)returnBlock 
{ 
  BOOL isOPen = NO; 
  if ([CLLocationManager locationServicesEnabled] && [CLLocationManager authorizationStatus] != kCLAuthorizationStatusDenied) { 
    isOPen = YES; 
  } 
  if (returnBlock) { 
    returnBlock(isOpen); 
  } 
} 

2.iOS開(kāi)發(fā)檢測(cè)是否允許消息推送:

需要導(dǎo)入:

#import <UserNotifications/UserNotifications.h> 

代碼如下:

+ (void)openMessageNotificationServiceWithBlock:(ReturnBlock)returnBlock 
{ 
 BOOL isOpen = NO; 
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_8_0 
 UIUserNotificationSettings *setting = [[UIApplication sharedApplication] currentUserNotificationSettings]; 
 if (setting.types != UIUserNotificationTypeNone) { 
  isOpen = YES; 
 } 
#else 
 UIRemoteNotificationType type = [[UIApplication sharedApplication] enabledRemoteNotificationTypes]; 
 if (type != UIRemoteNotificationTypeNone) { 
  isOpen = YES; 
 } 
#endif 
 if (returnBlock) { 
  returnBlock(isOpen); 
 } 
} 
+ (void)openMessageNotificationServiceWithBlock:(ReturnBlock)returnBlock 
{ 
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0 
 [[UNUserNotificationCenter currentNotificationCenter] getNotificationSettingsWithCompletionHandler:^(UNNotificationSettings *settings) { 
  if (returnBlock) { 
   returnBlock(settings.authorizationStatus == UNAuthorizationStatusAuthorized); 
  } 
 }]; 
#elif __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_8_0 
 returnBlock([[UIApplication sharedApplication] isRegisteredForRemoteNotifications]); 
#else 
 UIRemoteNotificationType type = [[UIApplication sharedApplication] enabledRemoteNotificationTypes]; 
 if (returnBlock) { 
  returnBlock(type != UIRemoteNotificationTypeNone); 
 } 
#endif 
} 

3.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟攝像頭:

需要導(dǎo)入:

#import <AVFoundation/AVFoundation.h> 

代碼如下:

+ (void)openCaptureDeviceServiceWithBlock:(ReturnBlock)returnBlock 
{ 
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_7_0 
  AVAuthorizationStatus authStatus = [AVCaptureDevice authorizationStatusForMediaType:AVMediaTypeVideo]; 
  if (authStatus == AVAuthorizationStatusNotDetermined) { 
    [AVCaptureDevice requestAccessForMediaType:AVMediaTypeVideo completionHandler:^(BOOL granted) { 
      if (returnBlock) { 
        returnBlock(granted); 
      } 
    }]; 
    return NO; 
  } else if (authStatus == AVAuthorizationStatusRestricted || authStatus == AVAuthorizationStatusDenied) { 
    returnBlock(NO); 
  } else { 
    returnBlock(YES); 
  } 
#endif 
} 

4.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟相冊(cè):

需要導(dǎo)入:

#import <Photos/Photos.h>#import <AssetsLibrary/AssetsLibrary.h> 

代碼如下:

+ (void)openAlbumServiceWithBlock:(ReturnBlock)returnBlock 
{ 
  BOOL isOpen; 
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_8_0 
  PHAuthorizationStatus authStatus = [PHPhotoLibrary authorizationStatus]; 
  isOpen = YES; 
  if (authStatus == PHAuthorizationStatusRestricted || authStatus == PHAuthorizationStatusDenied) { 
    isOpen = NO; 
  } 
#else 
  ALAuthorizationStatus author = [ALAssetsLibrary authorizationStatus]; 
  isOpen = YES; 
  if (author == ALAuthorizationStatusRestricted || author == ALAuthorizationStatusDenied) { 
    isOpen = NO; 
  } 
#endif 
  if (returnBlock) { 
    returnBlock(isOpen); 
  } 
} 

5.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟麥克風(fēng):

需要導(dǎo)入:

#import <AVFoundation/AVFoundation.h> 

代碼如下:

+ (void)openRecordServiceWithBlock:(ReturnBlock)returnBlock 
{ 
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_8_0 
  AVAudioSessionRecordPermission permissionStatus = [[AVAudioSession sharedInstance] recordPermission]; 
  if (permissionStatus == AVAudioSessionRecordPermissionUndetermined) { 
    [[AVAudioSession sharedInstance] requestRecordPermission:^(BOOL granted) { 
      if (returnBlock) { 
        returnBlock(granted); 
      } 
    }]; 
  } else if (permissionStatus == AVAudioSessionRecordPermissionDenied) { 
    returnBlock(NO); 
  } else { 
    returnBlock(YES); 
  } 
#endif 
} 

6.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟通訊錄:

需要導(dǎo)入:

#import <AddressBook/AddressBook.h>#import <Contacts/Contacts.h> 

代碼如下:

+ (void)openContactsServiceWithBolck:(ReturnBlock)returnBolck
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_9_0
 CNAuthorizationStatus cnAuthStatus = [CNContactStore authorizationStatusForEntityType:CNEntityTypeContacts];
 if (cnAuthStatus == CNAuthorizationStatusNotDetermined) {
  CNContactStore *store = [[CNContactStore alloc] init];
  [store requestAccessForEntityType:CNEntityTypeContacts completionHandler:^(BOOL granted, NSError *error) {
   if (returnBolck) {
    returnBolck(granted);
   }
  }];
 } else if (cnAuthStatus == CNAuthorizationStatusRestricted || cnAuthStatus == CNAuthorizationStatusDenied) {
  if (returnBolck) {
   returnBolck(NO);
  }
 } else {
  if (returnBolck) {
   returnBolck(YES);
  }
 }
#else
 //ABAddressBookRef addressBook = ABAddressBookCreateWithOptions(NULL, NULL);
 ABAddressBookRef addressBook = ABAddressBookCreate();
 ABAuthorizationStatus authStatus = ABAddressBookGetAuthorizationStatus();
 if (authStatus != kABAuthorizationStatusAuthorized) {
  ABAddressBookRequestAccessWithCompletion(addressBook, ^(bool granted, CFErrorRef error) {
   dispatch_async(dispatch_get_main_queue(), ^{
    if (error) {
     NSLog(@"Error: %@", (__bridge NSError *)error);
     if (returnBolck) {
      returnBolck(NO);
     }
    } else {
     if (returnBolck) {
      returnBolck(YES);
     }
    }
   });
  });
 } else {
  if (returnBolck) {
   returnBolck(YES);
  }
 }
#endif
}

7.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟藍(lán)牙:

需要導(dǎo)入:

#import <CoreBluetooth/CoreBluetooth.h> 

代碼如下:

+ (void)openPeripheralServiceWithBolck:(ReturnBlock)returnBolck 
{ 
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_7_0 
  CBPeripheralManagerAuthorizationStatus cbAuthStatus = [CBPeripheralManager authorizationStatus]; 
  if (cbAuthStatus == CBPeripheralManagerAuthorizationStatusNotDetermined) { 
    if (returnBolck) { 
      returnBolck(NO); 
    } 
  } else if (cbAuthStatus == CBPeripheralManagerAuthorizationStatusRestricted || cbAuthStatus == CBPeripheralManagerAuthorizationStatusDenied) { 
    if (returnBolck) { 
      returnBolck(NO); 
    } 
  } else { 
    if (returnBolck) { 
      returnBolck(YES); 
    } 
  } 
#endif 
} 

8.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟日歷/備忘錄:

需要導(dǎo)入:

#import <EventKit/EventKit.h> 

代碼如下:

+ (void)openEventServiceWithBolck:(ReturnBlock)returnBolck withType:(EKEntityType)entityType 
{ 
  // EKEntityTypeEvent  代表日歷 
  // EKEntityTypeReminder 代表備忘 
  EKAuthorizationStatus ekAuthStatus = [EKEventStore authorizationStatusForEntityType:entityType]; 
  if (ekAuthStatus == EKAuthorizationStatusNotDetermined) { 
    EKEventStore *store = [[EKEventStore alloc] init]; 
    [store requestAccessToEntityType:entityType completion:^(BOOL granted, NSError *error) { 
      if (returnBolck) { 
        returnBolck(granted); 
      } 
    }]; 
  } else if (ekAuthStatus == EKAuthorizationStatusRestricted || ekAuthStatus == EKAuthorizationStatusDenied) { 
    if (returnBolck) { 
      returnBolck(NO); 
    } 
  } else { 
    if (returnBolck) { 
      returnBolck(YES); 
    } 
  } 
} 

9.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟聯(lián)網(wǎng):

需要導(dǎo)入:

#import <CoreTelephony/CTCellularData.h> 

代碼如下:

+ (void)openEventServiceWithBolck:(ReturnBlock)returnBolck 
{ 
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_9_0 
  CTCellularData *cellularData = [[CTCellularData alloc] init]; 
  cellularData.cellularDataRestrictionDidUpdateNotifier = ^(CTCellularDataRestrictedState state){ 
    if (state == kCTCellularDataRestrictedStateUnknown || state == kCTCellularDataNotRestricted) { 
      if (returnBolck) { 
        returnBolck(NO); 
      } 
    } else { 
      if (returnBolck) { 
        returnBolck(YES); 
      } 
    } 
  }; 
  CTCellularDataRestrictedState state = cellularData.restrictedState; 
  if (state == kCTCellularDataRestrictedStateUnknown || state == kCTCellularDataNotRestricted) { 
    if (returnBolck) { 
      returnBolck(NO); 
    } 
  } else { 
    if (returnBolck) { 
      returnBolck(YES); 
    } 
  } 
#endif 
} 

10.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟健康:

需要導(dǎo)入:

#import <HealthKit/HealthKit.h> 

代碼如下:

+ (void)openHealthServiceWithBolck:(ReturnBlock)returnBolck
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_8_0
 if (![HKHealthStore isHealthDataAvailable]) {
  if (returnBolck) {
   returnBolck(NO);
  }
 } else {
  HKHealthStore *healthStore = [[HKHealthStore alloc] init];
  HKObjectType *hkObjectType = [HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierHeight];
  HKAuthorizationStatus hkAuthStatus = [healthStore authorizationStatusForType:hkObjectType];
  if (hkAuthStatus == HKAuthorizationStatusNotDetermined) {
   // 1. 你創(chuàng)建了一個(gè)NSSet對(duì)象,里面存有本篇教程中你將需要用到的從Health Stroe中讀取的所有的類型:個(gè)人特征(血液類型、性別、出生日期)、數(shù)據(jù)采樣信息(身體質(zhì)量、身高)以及鍛煉與健身的信息。
   NSSet <HKObjectType *> * healthKitTypesToRead = [[NSSet alloc] initWithArray:@[[HKObjectType characteristicTypeForIdentifier:HKCharacteristicTypeIdentifierDateOfBirth],[HKObjectType characteristicTypeForIdentifier:HKCharacteristicTypeIdentifierBloodType],[HKObjectType characteristicTypeForIdentifier:HKCharacteristicTypeIdentifierBiologicalSex],[HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierBodyMass],[HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierHeight],[HKObjectType workoutType]]];
   // 2. 你創(chuàng)建了另一個(gè)NSSet對(duì)象,里面有你需要向Store寫入的信息的所有類型(鍛煉與健身的信息、BMI、能量消耗、運(yùn)動(dòng)距離)
   NSSet <HKSampleType *> * healthKitTypesToWrite = [[NSSet alloc] initWithArray:@[[HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierBodyMassIndex],[HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierActiveEnergyBurned],[HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierDistanceWalkingRunning],[HKObjectType workoutType]]];
   [healthStore requestAuthorizationToShareTypes:healthKitTypesToWrite readTypes:healthKitTypesToRead completion:^(BOOL success, NSError *error) {
    if (returnBolck) {
     returnBolck(success);
    }
   }];
  } else if (hkAuthStatus == HKAuthorizationStatusSharingDenied) {
   if (returnBolck) {
    returnBolck(NO);
   }
  } else {
   if (returnBolck) {
    returnBolck(YES);
   }
  }
 }
#endif
}

11.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟Touch ID:

需要導(dǎo)入:

#import <LocalAuthentication/LocalAuthentication.h>

代碼如下:

#pragma mark - 開(kāi)啟Touch ID服務(wù)
+ (void)openTouchIDServiceWithBlock:(ReturnBlock)returnBlock
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_8_0
 LAContext *laContext = [[LAContext alloc] init];
 laContext.localizedFallbackTitle = @"輸入密碼";
 NSError *error;
 if ([laContext canEvaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics error:&error]) {
  NSLog(@"恭喜,Touch ID可以使用!");
  [laContext evaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics localizedReason:@"需要驗(yàn)證您的指紋來(lái)確認(rèn)您的身份信息" reply:^(BOOL success, NSError *error) {
   if (success) {
    // 識(shí)別成功
    if (returnBlock) {
     [[NSOperationQueue mainQueue] addOperationWithBlock:^{
      returnBlock(YES);
     }];
    }
   } else if (error) {
    if (returnBlock) {
     [[NSOperationQueue mainQueue] addOperationWithBlock:^{
      returnBlock(NO);
     }];
    }
    if (error.code == LAErrorAuthenticationFailed) {
     // 驗(yàn)證失敗
    }
    if (error.code == LAErrorUserCancel) {
     // 用戶取消
    }
    if (error.code == LAErrorUserFallback) {
     // 用戶選擇輸入密碼
    }
    if (error.code == LAErrorSystemCancel) {
     // 系統(tǒng)取消
    }
    if (error.code == LAErrorPasscodeNotSet) {
     // 密碼沒(méi)有設(shè)置
    }
   }
  }];
 } else {
  NSLog(@"設(shè)備不支持Touch ID功能,原因:%@",error);
  if (returnBlock) {
   returnBlock(NO);
  }
 }
#endif
}

12.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟Apple Pay:

需要導(dǎo)入:

#import <PassKit/PassKit.h> 

代碼如下:

#pragma mark - 開(kāi)啟Apple Pay服務(wù) 
+ (void)openApplePayServiceWithBlock:(ReturnBlock)returnBlock 
{ 
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_9_0 
  NSArray<PKPaymentNetwork> *supportedNetworks = @[PKPaymentNetworkAmex, PKPaymentNetworkMasterCard, PKPaymentNetworkVisa, PKPaymentNetworkDiscover]; 
  if ([PKPaymentAuthorizationViewController canMakePayments] && [PKPaymentAuthorizationViewController canMakePaymentsUsingNetworks:supportedNetworks]) { 
    if (returnBlock) { 
      returnBlock(YES); 
    } 
  } else { 
    if (returnBlock) { 
      returnBlock(NO); 
    } 
  } 
#endif 
} 

13.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟語(yǔ)音識(shí)別:

需要導(dǎo)入:

#import <Speech/Speech.h> 

代碼如下:

#pragma mark - 開(kāi)啟語(yǔ)音識(shí)別服務(wù)
+ (void)openSpeechServiceWithBlock:(ReturnBlock)returnBlock
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0
 SFSpeechRecognizerAuthorizationStatus speechAuthStatus = [SFSpeechRecognizer authorizationStatus];
 if (speechAuthStatus == SFSpeechRecognizerAuthorizationStatusNotDetermined) {
  [SFSpeechRecognizer requestAuthorization:^(SFSpeechRecognizerAuthorizationStatus status) {
   if (status == SFSpeechRecognizerAuthorizationStatusAuthorized) {
    dispatch_async(dispatch_get_main_queue(), ^{
     if (returnBlock) {
      returnBlock(YES);
     }
    });
   } else {
    dispatch_async(dispatch_get_main_queue(), ^{
     if (returnBlock) {
      returnBlock(YES);
     }
    });
   }
  }];
 } else if (speechAuthStatus == SFSpeechRecognizerAuthorizationStatusAuthorized) {
  if (returnBlock) {
   returnBlock(YES);
  }
 } else{
  if (returnBlock) {
   returnBlock(NO);
  }
 }
#endif
}

14.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟媒體資料庫(kù)/Apple Music:

需要導(dǎo)入:

#import <MediaPlayer/MediaPlayer.h> 

代碼如下:

#pragma mark - 開(kāi)啟媒體資料庫(kù)/Apple Music 服務(wù)
+ (void)openMediaPlayerServiceWithBlock:(ReturnBlock)returnBlock
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_9_3
 MPMediaLibraryAuthorizationStatus authStatus = [MPMediaLibrary authorizationStatus];
 if (authStatus == MPMediaLibraryAuthorizationStatusNotDetermined) {
  [MPMediaLibrary requestAuthorization:^(MPMediaLibraryAuthorizationStatus status) {
   if (status == MPMediaLibraryAuthorizationStatusAuthorized) {
    dispatch_async(dispatch_get_main_queue(), ^{
     if (returnBlock) {
      returnBlock(YES);
     }
    });
   }else{
    dispatch_async(dispatch_get_main_queue(), ^{
     if (returnBlock) {
      returnBlock(NO);
     }
    });
   }
  }];
 }else if (authStatus == MPMediaLibraryAuthorizationStatusAuthorized){
  if (returnBlock) {
   returnBlock(YES);
  }
 }else{
  if (returnBlock) {
   returnBlock(NO);
  }
 }
#endif
}

15.iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟Siri:

需要導(dǎo)入:

#import <Intents/Intents.h> 

代碼如下:

#pragma mark - 開(kāi)啟Siri服務(wù)
+ (void)openSiriServiceWithBlock:(ReturnBlock)returnBlock
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0
 INSiriAuthorizationStatus siriAutoStatus = [INPreferences siriAuthorizationStatus];
 if (siriAutoStatus == INSiriAuthorizationStatusNotDetermined) {
  [INPreferences requestSiriAuthorization:^(INSiriAuthorizationStatus status) {
   if (status == INSiriAuthorizationStatusAuthorized) {
    dispatch_async(dispatch_get_main_queue(), ^{
     if (returnBlock) {
      returnBlock(YES);
     }
    });
   } else {
    dispatch_async(dispatch_get_main_queue(), ^{
     if (returnBlock) {
      returnBlock(YES);
     }
    });
   }
  }];
 } else if (siriAutoStatus == INSiriAuthorizationStatusAuthorized) {
  if (returnBlock) {
   returnBlock(YES);
  }
 } else{
  if (returnBlock) {
   returnBlock(NO);
  }
 }
#endif
}

在.h文件中申明block

#if NS_BLOCKS_AVAILABLE 
typedef void(^ReturnBlock)(BOOL isOpen); 
#endif 

由于iOS10的權(quán)限原因,需要在工程的info.plist(右擊選擇Open as - Source Code)中添加

<!-- 相冊(cè) --> 
<key>NSPhotoLibraryUsageDescription</key> 
<string>App需要您的同意,才能訪問(wèn)相冊(cè)</string> 
<!-- 相機(jī) --> 
<key>NSCameraUsageDescription</key> 
<string>App需要您的同意,才能訪問(wèn)相機(jī)</string> 
<!-- 麥克風(fēng) --> 
<key>NSMicrophoneUsageDescription</key> 
<string>App需要您的同意,才能訪問(wèn)麥克風(fēng)</string> 
<!-- 位置 --> 
<key>NSLocationUsageDescription</key> 
<string>App需要您的同意,才能訪問(wèn)位置</string> 
<!-- 在使用期間訪問(wèn)位置 --> 
<key>NSLocationWhenInUseUsageDescription</key> 
<string>App需要您的同意,才能在使用期間訪問(wèn)位置</string> 
<!-- 始終訪問(wèn)位置 --> 
<key>NSLocationAlwaysUsageDescription</key> 
<string>App需要您的同意,才能始終訪問(wèn)位置</string> 
<!-- 日歷 --> 
<key>NSCalendarsUsageDescription</key> 
<string>App需要您的同意,才能訪問(wèn)日歷</string> 
<!-- 提醒事項(xiàng) --> 
<key>NSRemindersUsageDescription</key> 
<string>App需要您的同意,才能訪問(wèn)提醒事項(xiàng)</string> 
<!-- 運(yùn)動(dòng)與健身 --> 
<key>NSMotionUsageDescription</key>
 <string>App需要您的同意,才能訪問(wèn)運(yùn)動(dòng)與健身</string> 
<!-- 健康更新 --> 
<key>NSHealthUpdateUsageDescription</key> 
<string>App需要您的同意,才能訪問(wèn)健康更新 </string> 
<!-- 健康分享 --> 
<key>NSHealthShareUsageDescription</key> 
<string>App需要您的同意,才能訪問(wèn)健康分享</string> 
<!-- 藍(lán)牙 --> 
<key>NSBluetoothPeripheralUsageDescription</key> 
<string>App需要您的同意,才能訪問(wèn)藍(lán)牙</string> 
<!-- 媒體資料庫(kù) --> 
<key>NSAppleMusicUsageDescription</key> 
<string>App需要您的同意,才能訪問(wèn)媒體資料庫(kù)</string>
<!-- 語(yǔ)音識(shí)別 --> 
<key>NSSpeechRecognitionUsageDescription</key> 
<string>App需要您的同意,才能使用語(yǔ)音識(shí)別</string>

以上這篇iOS開(kāi)發(fā)檢測(cè)是否開(kāi)啟定位、是否允許消息推送等權(quán)限的實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 解決ios audio無(wú)法播放問(wèn)題

    解決ios audio無(wú)法播放問(wèn)題

    這篇文章主要介紹了解決ios audio無(wú)法播放問(wèn)題,并給大家分享了解決方法,需要的朋友參考一下。
    2017-11-11
  • iOS屏幕適配開(kāi)發(fā)實(shí)用技巧

    iOS屏幕適配開(kāi)發(fā)實(shí)用技巧

    這篇文章主要為大家詳細(xì)介紹了iOS屏幕適配開(kāi)發(fā)實(shí)用技巧,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • IOS 打包靜態(tài)庫(kù)詳細(xì)介紹

    IOS 打包靜態(tài)庫(kù)詳細(xì)介紹

    這篇文章主要介紹了IOS 打包靜態(tài)庫(kù)詳細(xì)介紹的相關(guān)資料,這里對(duì)打包靜態(tài)庫(kù)做了詳細(xì)的說(shuō)明,并進(jìn)行了總結(jié),需要的朋友可以參考下
    2016-11-11
  • iOS下拉刷新 UIScrollVie異常閃動(dòng)問(wèn)題

    iOS下拉刷新 UIScrollVie異常閃動(dòng)問(wèn)題

    這篇文章主要介紹了iOS下拉刷新 UIScrollVie異常閃動(dòng)問(wèn)題,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-03-03
  • IOS 中NSTimer定時(shí)器的使用

    IOS 中NSTimer定時(shí)器的使用

    這篇文章主要介紹了IOS 中NSTimer定時(shí)器的使用的相關(guān)資料,希望通過(guò)本文能幫助到大家,能讓大家徹底理解使用該方法,需要的朋友可以參考下
    2017-10-10
  • iOS?Lotusoot模塊化工具應(yīng)用的動(dòng)態(tài)思路

    iOS?Lotusoot模塊化工具應(yīng)用的動(dòng)態(tài)思路

    項(xiàng)目的不斷更迭,導(dǎo)致項(xiàng)目越來(lái)越大,越來(lái)越臃腫,為了讓項(xiàng)目更加條理,需要對(duì)項(xiàng)目進(jìn)行模塊化處理,為了減少模塊之間的耦合,于是就有了Lotusoot這個(gè)工具
    2022-08-08
  • iOS中關(guān)于Cookie驗(yàn)證登錄狀態(tài)

    iOS中關(guān)于Cookie驗(yàn)證登錄狀態(tài)

    這篇文章主要介紹了iOS中關(guān)于Cookie驗(yàn)證登錄狀態(tài)的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • iOS13適配的實(shí)現(xiàn)方法

    iOS13適配的實(shí)現(xiàn)方法

    這篇文章主要介紹了iOS13適配的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • iOS Crash文件分析方法匯總

    iOS Crash文件分析方法匯總

    今天跟大家一起聊聊iOSCrash文件的幾種分析方法,都是平時(shí)比較常用的,有需要的小伙伴可以參考下
    2017-11-11
  • iOS 監(jiān)聽(tīng)回調(diào)機(jī)制KVO實(shí)例

    iOS 監(jiān)聽(tīng)回調(diào)機(jī)制KVO實(shí)例

    下面小編就為大家分享一篇iOS 監(jiān)聽(tīng)回調(diào)機(jī)制KVO實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-01-01

最新評(píng)論