iOS开发 Object-C 与 Swift 中的Touch ID开发 重磅出击3DTouch 仅限于6s或以上机型实用

本文介绍如何在iOS应用中实现3DTouch快捷操作及TouchID验证,并提供了Objective-C和Swift两种语言的示例代码。

3DTouch 重磅出击


效果图:



只需要简单的几部就可以完成。


在 Info.plist 中添加

   UIApplicationShortcutItems   为Array类型

     在其内部添加一个   Item 为 Dictionar类型

  在Item 下添加如下几个键:

1. UIApplicationShortcutItemType     string类型:-11.UITouchText.share

2. UIApplicationShortcutItemTitle    string类型:Share

3.   UIApplicationShortcutItemIconType string类型:UIApplicationShortcutIconTypeShare



AppDelegate中添加如下方法:

- (void)application:(UIApplication *)application

  performActionForShortcutItem:(UIApplicationShortcutItem *)shortcutItem

  completionHandler:(void(^)(BOOL succeeded))completionHandler{


//判断先前我们设置的唯一标识

    if([shortcutItem.type isEqualToString:@"-11.UITouchText.share"]){

        //点击后执行的内容


    }

}






Object-C  Touch ID 验证

导入库 



#import <LocalAuthentication/LocalAuthentication.h>


- (IBAction)btnClick:(UIButton *)sender {

    //初始化上下文对象

    LAContext* context = [[LAContextalloc] init];

    //错误对象

    NSError* error = nil;

    NSString* result =@"Authentication is needed to access your notes.";

    

    //首先使用canEvaluatePolicy判断设备支持状态

    if ([contextcanEvaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometricserror:&error]) {

        //支持指纹验证

        [context evaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometricslocalizedReason:result reply:^(BOOL success,NSError *error) {

            if (success) {

                //验证成功,主线程处理UI

                dispatch_async(dispatch_get_main_queue(), ^{

                    UIAlertView * alert = [[UIAlertViewalloc]initWithTitle:@"Touch ID"message:@"验证成功"delegate:nilcancelButtonTitle:@"好的"otherButtonTitles: nil];

                    [alert show];

                });

            }

            else

            {

                NSLog(@"%@",error.localizedDescription);

                switch (error.code) {

                    case LAErrorSystemCancel:

                    {

                        NSLog(@"Authentication was cancelled by the system");

                        //切换到其他APP,系统取消验证Touch ID

                        break;

                    }

                    case LAErrorUserCancel:

                    {

                        NSLog(@"Authentication was cancelled by the user");

                        //用户取消验证Touch ID

                        break;

                    }

                    case LAErrorUserFallback:

                    {

                        NSLog(@"User selected to enter custom password");

                        [[NSOperationQueue mainQueue] addOperationWithBlock:^{

                            //用户选择输入密码,切换主线程处理

                        }];

                        break;

                    }

                    default:

                    {

                        [[NSOperationQueue mainQueue] addOperationWithBlock:^{

                            //其他情况,切换主线程处理

                        }];

                        break;

                    }

                }

            }

        }];

    }

    else

    {

        //不支持指纹识别,LOG出错误详情

        

        switch (error.code) {

            caseLAErrorTouchIDNotEnrolled:

            {

                NSLog(@"TouchID is not enrolled");

                break;

            }

            caseLAErrorPasscodeNotSet:

            {

                NSLog(@"A passcode has not been set");

                break;

            }

            default:

            {

                NSLog(@"TouchID not available");

                break;

            }

        }

        

        NSLog(@"%@",error.localizedDescription);

    }

}



Swift Touch ID 验证

导入库 跟 Object-C 一样framework 就可以了


    func MyBtnClick(sender: MyButton) {

        print("-------",sender)

        

        let laContext = LAContext()

        var authError : NSError?

        let errorReason = "需要验证Touch ID"

        

        if laContext.canEvaluatePolicy(LAPolicy.DeviceOwnerAuthenticationWithBiometrics, error: &authError){

            laContext.evaluatePolicy(LAPolicy.DeviceOwnerAuthenticationWithBiometrics, localizedReason: errorReason, reply: {

                (success, error) in

                if success {

                    print ( "Touch ID 验证成功")

                }

                else{

                    print ( "Touch ID 验证失败")

                }

            })

        }

        else{

            let alert = UIAlertView(title: "Can not do authenticatation", message:String(authError), delegate: nil, cancelButtonTitle: "Cancel")

            alert.show()

        }

    }

附:

/*

 typedef NS_ENUM(NSInteger, LAError)

 {

 

 //授权失败

 LAErrorAuthenticationFailed = kLAErrorAuthenticationFailed,

 

 //用户取消Touch ID授权

 LAErrorUserCancel           = kLAErrorUserCancel,

 

 //用户选择输入密码

 LAErrorUserFallback         = kLAErrorUserFallback,

 

 //系统取消授权(例如其他APP切入)

 LAErrorSystemCancel         = kLAErrorSystemCancel,

 

 //系统未设置密码

 LAErrorPasscodeNotSet       = kLAErrorPasscodeNotSet,

 

 //设备Touch ID不可用,例如未打开

 LAErrorTouchIDNotAvailable  = kLAErrorTouchIDNotAvailable,

 

 //设备Touch ID不可用,用户未录入

 LAErrorTouchIDNotEnrolled   = kLAErrorTouchIDNotEnrolled,

 } NS_ENUM_AVAILABLE(10_10, 8_0);

 

 */

谢谢浏览!!!




内容概要:本文提出了一种基于非合作博弈理论的居民负荷分层调度模型,并结合双层鲸鱼优化算法(Two-level Whale Optimization Algorithm)进行高效求解,模型算法均通过Matlab代码实现。研究针对电力系统中居民侧用电负荷的复杂调度问题,引入非合作博弈机制刻画各用户之间的利益竞争关系,实现负荷的分层优化分配;同时设计双层优化架构,上层优化资源配置,下层模拟用户自主决策行为,提升了模型的实用合理性。通过智能优化算法求解多层级、非凸非线性的博弈模型,有效提高了调度方案的收敛性全局寻优能力,适用于现代智能电网中的需求侧管理能源优化场景。; 适合人群:具备电力系统基础理论知识和Matlab编程能力,从事智能电网、能源优化调度、需求侧管理、博弈论应用等方向的科研人员、高校研究生及工程技术人员。; 使用场景及目标:①应用于居民区电力负荷的分层优化调度系统设计仿真分析;②为非合作博弈在多主体能源系统建模中的应用提供方法论支持;③利用双层鲸鱼算法解决具有嵌套结构的复杂双层优化问题,提升求解效率调度方案的可行性。; 阅读建议:建议读者结合提供的Matlab代码深入理解模型构建逻辑算法实现流程,重点关注博弈模型的效用函数设计、纳什均衡求解思路以及双层优化结构的迭代机制,宜配合实际用电数据开展复现实验以验证模型有效性鲁棒性。
内容概要:本文围绕基于自适应神经模糊推理系统(ANFIS)智能控制器的可再生能源微电网功率管理系统展开研究,结合Simulink仿真实现,深入探讨了微电网中功率的智能调控经济机组组合调度问题。通过引入ANFIS控制器,有效应对风能、光伏等可再生能源出力的波动性不确定性,提升系统运行的稳定性电能质量。研究内容涵盖微电网多源协调控制策略、功率平衡管理、优化调度模型构建及仿真验证,实现了对分布式电源、储能系统和负荷的协同优化,兼顾经济性可靠性目标,并通过仿真平台验证了所提方法的有效性优越性。; 适合人群:具备电力系统、自动化新能源相关专业背景,熟悉Matlab/Simulink仿真环境,从事微电网能量管理、智能控制、能源优化等领域研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①用于高比例可再生能源接入场景下的微电网能量管理系统研发教学实践;②为实现微电网功率稳定控制经济高效运行提供先进的智能控制解决方案;③支撑高水平学术论文复现、科研课题攻关及实际工程项目的仿真验证方案优化。; 阅读建议:建议结合提供的Simulink模型相关代码进行动手实践,重点关注ANFIS控制器的设计流程、规则库构建参数调优方法,并通过传统PIDMPC控制策略的对比实验,深入理解其在动态响应鲁棒性方面的优势。同时可进一步拓展文中提出的优化调度逻辑,应用于多目标、多约束的复杂实际应用场景中。
内容概要:本文档聚焦于“直流电机双闭环控制Matlab仿真”,系统阐述了基于Matlab/Simulink平台实现直流电机双闭环控制系统(主要包括速度环电流环)的设计仿真全过程。通过构建直流电机的数学模型,结合PI控制器进行调控,实现对电机转速和电枢电流的高精度动态控制,验证控制策略的稳定性响应性能。文档详细介绍了仿真模型的搭建流程、关键参数的整定方法、系统动态波形的分析手段以及仿真结果的有效性验证,体现了经典自动控制理论在实际电机系统中的工程应用,是电机控制电力电子技术相结合的典型研究案例。; 适合人群:具备自动控制原理、电机拖动基础、电力电子技术和Matlab/Simulink仿真能力的电气工程、自动化、机电一体化等专业的本科生、研究生及从事电机驱动系统研发的工程技术人员。; 使用场景及目标:①作为高校课程设计实验教学材料,帮助学生深入理解双闭环调速系统的工作机理工程实现;②服务于科研项目,为新型电机控制算法(如滑模、模糊PID等)的开发性能对比提供基础仿真验证平台;③作为工业界产品前期设计的仿真工具,用于评估不同控制策略在动态响应、抗干扰能力和稳态精度方面的可行性。; 阅读建议:建议读者在学习过程中紧密结合自动控制理论知识,亲手在Simulink环境中搭建完整的双闭环仿真模型,通过反复调整PI控制器的比例积分参数,观察并分析转速、电流的阶跃响应曲线,从而深刻理解反馈控制的本质、系统稳定性条件以及参数整定对动态性能的影响,进而掌握电机控制系统的设计精髓。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值