zoukankan      html  css  js  c++  java
  • iOS开发- 蓝牙后台接收数据(BLE4.0)

    最近在做一个蓝牙相关的项目, 需要在应用进入后台, 或者手机属于锁屏状态的情况下, 仍然保持蓝牙连接, 并且能正常接收数据。

    本来以后会很麻烦, 但是学习了下..发现就2步而已。简单的不能再简单了。

    好了。下面是具体实现办法。

    1.在xxx-info.plist文件中, 新建一行  Required background modes
     , 加入下面两项。

    App shares data using CoreBluetooth
     和  App communicates using CoreBluetooth

    如图所示:

    加入这个项后, 你会发现, 当应用进入后台后, 蓝牙还是保持连接的。

    但是, 进入后台后, 虽然应用还挂着, 能够正常接收数据。但是,  来数据了, 如果需要我们实时响应, 那就要用到推送了。

    也就是, 当数据来的时候, 弹出一个提示框, 提示用户来数据了。

    2. 设置本地推送

    这里的方法写在AppDelegate.m中。  receiveData对应你接收到数据的响应函数。

    -(void)receiveData:(NSData*)data  
    {  
        NSLog(@"收到数据了");  
          
        //收到数据, 设置推送  
        UILocalNotification *noti = [[UILocalNotification alloc] init];  
        if (noti)  
        {  
            //设置时区  
            noti.timeZone = [NSTimeZone defaultTimeZone];  
            //设置重复间隔  
            noti.repeatInterval = NSWeekCalendarUnit;  
            //推送声音  
            noti.soundName = UILocalNotificationDefaultSoundName;  
            //内容  
            noti.alertBody = @"接收到数据了";  
            noti.alertAction = @"打开";  
            //显示在icon上的红色圈中的数子  
            noti.applicationIconBadgeNumber = 1;  
            //设置userinfo 方便在之后需要撤销的时候使用  
            NSDictionary *infoDic = [NSDictionary dictionaryWithObject:@"name" forKey:@"key"];  
            noti.userInfo = infoDic;  
            //添加推送到uiapplication  
            UIApplication *app = [UIApplication sharedApplication];  
            [app scheduleLocalNotification:noti];  
        }  
    }  
    #pragma mark - 接收到推送  
    - (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification*)notification  
    {  
        UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"来电提示"  
                                                        message:notification.alertBody  
                                                       delegate:nil  
                                              cancelButtonTitle:@"接听"  
                                              otherButtonTitles:@"挂断",nil];  
        [alert show];  
        //这里,你就可以通过notification的useinfo,干一些你想做的事情了  
        application.applicationIconBadgeNumber -= 1;  
    }  
  • 相关阅读:
    前端面试常考知识点---CSS
    vue中的适配:px2rem
    判断DOM元素是否出现再浏览器窗口中
    前端构建:3类13种热门工具的选型参考
    webpack4 中的最新 React全家桶实战使用配置指南!
    [C++] 自动关闭右下角弹窗
    Java RandomAccessFile用法(转载)
    Java Annotation详解(二): 反射和Annotation
    Java Annotation详解(一): 理解和使用Annotation
    Java反射机制(五):使用反射增强简单工厂设计模式
  • 原文地址:https://www.cnblogs.com/yulang314/p/5088274.html
Copyright © 2011-2022 走看看