1.iOS开发检测是否开启定位:

需要导入:

#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开发检测是否允许消息推送:

需要导入:

#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开发检测是否开启摄像头:

需要导入:

#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开发检测是否开启相册:

需要导入:

#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开发检测是否开启麦克风:

需要导入:

#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开发检测是否开启通讯录:

需要导入:

#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开发检测是否开启蓝牙:

需要导入:

#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开发检测是否开启日历/备忘录:

需要导入:

#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开发检测是否开启联网:

需要导入:

#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开发检测是否开启健康:

需要导入:

#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. 你创建了一个NSSet对象,里面存有本篇教程中你将需要用到的从Health Stroe中读取的所有的类型:个人特征(血液类型、性别、出生日期)、数据采样信息(身体质量、身高)以及锻炼与健身的信息。
NSSet <HKObjectType *> * healthKitTypesToRead = [[NSSet alloc] initWithArray:@[[HKObjectType characteristicTypeForIdentifier:HKCharacteristicTypeIdentifierDateOfBirth],[HKObjectType characteristicTypeForIdentifier:HKCharacteristicTypeIdentifierBloodType],[HKObjectType characteristicTypeForIdentifier:HKCharacteristicTypeIdentifierBiologicalSex],[HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierBodyMass],[HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierHeight],[HKObjectType workoutType]]];
// 2. 你创建了另一个NSSet对象,里面有你需要向Store写入的信息的所有类型(锻炼与健身的信息、BMI、能量消耗、运动距离)
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开发检测是否开启Touch ID:

需要导入:

#import <LocalAuthentication/LocalAuthentication.h>

代码如下:

#pragma mark - 开启Touch ID服务
+ (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:@"需要验证您的指纹来确认您的身份信息" reply:^(BOOL success, NSError *error) {
if (success) {
// 识别成功
if (returnBlock) {
[[NSOperationQueue mainQueue] addOperationWithBlock:^{
returnBlock(YES);
}];
}
} else if (error) {
if (returnBlock) {
[[NSOperationQueue mainQueue] addOperationWithBlock:^{
returnBlock(NO);
}];
}
if (error.code == LAErrorAuthenticationFailed) {
// 验证失败
}
if (error.code == LAErrorUserCancel) {
// 用户取消
}
if (error.code == LAErrorUserFallback) {
// 用户选择输入密码
}
if (error.code == LAErrorSystemCancel) {
// 系统取消
}
if (error.code == LAErrorPasscodeNotSet) {
// 密码没有设置
}
}
}];
} else {
NSLog(@"设备不支持Touch ID功能,原因:%@",error);
if (returnBlock) {
returnBlock(NO);
}
}
#endif
}
12.iOS开发检测是否开启Apple Pay:

需要导入:

#import <PassKit/PassKit.h>

代码如下:

#pragma mark - 开启Apple Pay服务
+ (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开发检测是否开启语音识别:

需要导入:

#import <Speech/Speech.h>

代码如下:

#pragma mark - 开启语音识别服务
+ (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开发检测是否开启媒体资料库/Apple Music:

需要导入:

#import <MediaPlayer/MediaPlayer.h>

代码如下:

#pragma mark - 开启媒体资料库/Apple Music 服务
+ (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开发检测是否开启Siri:

需要导入:

#import <Intents/Intents.h>

代码如下:

#pragma mark - 开启Siri服务
+ (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的权限原因,需要在工程的info.plist(右击选择Open as - Source Code)中添加

<!-- 相册 -->
<key>NSPhotoLibraryUsageDescription</key>
<string>App需要您的同意,才能访问相册</string>
<!-- 相机 -->
<key>NSCameraUsageDescription</key>
<string>App需要您的同意,才能访问相机</string>
<!-- 麦克风 -->
<key>NSMicrophoneUsageDescription</key>
<string>App需要您的同意,才能访问麦克风</string>
<!-- 位置 -->
<key>NSLocationUsageDescription</key>
<string>App需要您的同意,才能访问位置</string>
<!-- 在使用期间访问位置 -->
<key>NSLocationWhenInUseUsageDescription</key>
<string>App需要您的同意,才能在使用期间访问位置</string>
<!-- 始终访问位置 -->
<key>NSLocationAlwaysUsageDescription</key>
<string>App需要您的同意,才能始终访问位置</string>
<!-- 日历 -->
<key>NSCalendarsUsageDescription</key>
<string>App需要您的同意,才能访问日历</string>
<!-- 提醒事项 -->
<key>NSRemindersUsageDescription</key>
<string>App需要您的同意,才能访问提醒事项</string>
<!-- 运动与健身 -->
<key>NSMotionUsageDescription</key>
<string>App需要您的同意,才能访问运动与健身</string>
<!-- 健康更新 -->
<key>NSHealthUpdateUsageDescription</key>
<string>App需要您的同意,才能访问健康更新 </string>
<!-- 健康分享 -->
<key>NSHealthShareUsageDescription</key>
<string>App需要您的同意,才能访问健康分享</string>
<!-- 蓝牙 -->
<key>NSBluetoothPeripheralUsageDescription</key>
<string>App需要您的同意,才能访问蓝牙</string>
<!-- 媒体资料库 -->
<key>NSAppleMusicUsageDescription</key>
<string>App需要您的同意,才能访问媒体资料库</string>
<!-- 语音识别 -->
<key>NSSpeechRecognitionUsageDescription</key>
<string>App需要您的同意,才能使用语音识别</string>

iOS开发检测是否开启定位、是否允许消息推送等权限的更多相关文章

  1. iOS开发笔记8:Remote Notification远程消息推送处理

    远程消息推送处理场景有三种:分别是app还没有运行.app在前台运行以及app在后台运行,下面介绍相关流程及三种场景下处理步骤 1.流程 (1)注册通知 首先是在注册远程消息推送,需要注意的是iOS8 ...

  2. [入门到吐槽系列] 微信小程序 敏感违规图片检测 mediaCheckAsync,客服接口 消息推送 的各种坑分享!

    前言: 最近需要做个用户上传图片,服务端校验图片问题的需求.需要使用小程序消息推送,异步接受腾讯的图片验证回调.实在太多坑了. 相信10分钟看完本文的朋友,可以非常顺利避坑. 前期准备: 首先需要一个 ...

  3. 了解iOS消息推送一文就够:史上最全iOS Push技术详解

    本文作者:陈裕发, 腾讯系统测试工程师,由腾讯WeTest整理发表. 1.引言 开发iOS系统中的Push推送,通常有以下3种情况: 1)在线Push:比如QQ.微信等IM界面处于前台时,聊天消息和指 ...

  4. 微信小程序开发:设置消息推送

    开发设置中,启用并设置消息推送配置后,用户发给小程序的消息以及开发者需要的事件推送,都将被微信转发至该服务器地址中. 不过照着说明去操作,即使按照最简单的明文方式去设置,还是提示Token验证失败.仔 ...

  5. iOS开发拓展篇—CoreLocation定位服务

    iOS开发拓展篇—CoreLocation定位服务 一.简单说明 1.CLLocationManager CLLocationManager的常用操作和属性 开始用户定位- (void)startUp ...

  6. iOS开发 检测版本更新

    iOS开发 检测版本更新的实现 苹果给了我们一个接口,能根据应用id请求一些关于应用的信息.我们可以根据返回的信息,来判断版本是否和应用的版本一致,如果不一致,那么就出现新的版本了.这时,就需要向用户 ...

  7. IOS开发之实现App消息推送

    转自:http://blog.csdn.net/shenjie12345678/article/details/41120637 第一部分 首先第一步当然是介绍一下苹果的推送机制(APNS)咯(ps: ...

  8. IOS开发之实现App消息推送(最新)

    好久没有写过博客啦,今天就由本菜鸟给大家做一个简单的IOSApp消息推送教程吧!一切从0开始,包括XCode6, IOS8, 以及苹果开发者中心最新如何注册应用,申请证书以及下载配置概要文件,相信很多 ...

  9. iOS 远程消息推送,原理和开发详解篇(新手推荐)

    1.APNS的推送机制 首先我们看一下苹果官方给出的对ios推送机制的解释.如下图 Provider就是我们自己程序的后台服务器,APNS是Apple Push Notification Servic ...

随机推荐

  1. vim修改二进制文件

    先用vim以二进制格式打开需要编辑或查看的文件,不采用-b参数有时会导致转换错误,详见分隔线后部分.    vim -b file-to-open.dat 然后用xxd把文件转换成十六进制格式 :%! ...

  2. centos 7 安装官方LAMP(Apache+PHP5+MySQL)

    启用Apache2 yum install httpd systemctl start httpd.service systemctl status httpd systemctl enable ht ...

  3. Linux内核模块编程与内核模块LICENSE -《具体解释(第3版)》预读

    Linux内核模块简单介绍 Linux内核的总体结构已经很庞大,而其包括的组件或许多.我们如何把须要的部分都包括在内核中呢?一种方法是把全部须要的功能都编译到Linux内核.这会导致两个问题.一是生成 ...

  4. JDBC MYSQL 学习笔记(一) JDBC 基本使用

    1.JDBC简单介绍 SUN公司为了简化.统一对数据库的操作,定义了一套Java操作数据库的规范.称之为JDBC. JDBC全称为:Java Data Base Connectivity(java数据 ...

  5. [POI 2001+2014acm上海邀请赛]Gold Mine/Beam Cannon 线段树+扫描线

    Description  Byteman, one of the most deserving employee of The Goldmine of Byteland, is about to re ...

  6. Material-Animations

    https://github.com/eltld/Material-Animations

  7. 使用脚本删除ios工程中未使用图片

    使用脚本删除ios工程中未使用图片 最近在读唐巧大神的<iOS开发进阶>,学到了一个大招:使用脚本删除ios中未使用的图片(纸书上有点小问题,参考github上的issue:使用脚本删除i ...

  8. gcc编译minigui新程序报错

    !ggcc *.c  -ljpeg -lpng  -lminigui -lpthread/usr/local/lib/libminigui.so: undefined reference to `dl ...

  9. V-Play 文档翻译 Page

    V-Play 文档翻译 Page 翻译:qyvlik 应用的一个页面. VPlayApps 1.0 Inherits: MouseArea Inherited By: ListPage 属性 Item ...

  10. android studio Error:Unable to tunnel through proxy. Proxy returns "HTTP/1.1 400 Bad Request"

    android studio运行会遇到Error:Unable to tunnel through proxy. Proxy returns "HTTP/1.1 400 Bad Reques ...