BLE藍牙ios(二)

今天我們來學習GameKit用法

  • 邏輯
    1.創建附近設備搜索框
    2.設置提示框代理
    3.調用方法展示提示框
    4.實現代理方法
    5.在代理方法中對傳輸數據進行處理

  • 代碼演示

1.在ViewController.m中導入
#import <GameKit/GameKit.h>

2.創建ui 搜索設備的btn、發送數據的btn、展示數據的imageView
<pre>
@property (nonatomic, strong) UIButton *clinkBtn;//建立連接
@property (nonatomic, strong) UIButton sendBtn;//發送數據
@property (nonatomic, strong) UIImageView imageView;//顯示數據
@property (nonatomic, strong) GKSession session;/
會話
/
// 注意UI懶加載代碼神略了哦
-(void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
[self setUpSubViews];
}
-(void)setUpSubViews{
[self.view addSubview:self.clinkBtn];
[self.view addSubview:self.sendBtn];
[self.view addSubview:self.imageView];
}
</pre>

3.在clinkBtn的點擊方法調用時創建附近設備的搜索提示框,并設置代理,并遵守協議<GKPeerPickerControllerDelegate>

-(void)clinkBtnAction{
    //創建一個附近設備的搜索提示框
    GKPeerPickerController *ppc = [[GKPeerPickerController alloc]init];//適配6.0,把版本號改成6.0,就不會再報警告
    //    如果要搜索到設備,還要用到代理方法
    ppc.delegate = self;
    
    [ppc show];
}

此時,我們運行代碼


屏幕快照 2016-11-27 下午3.19.14.png

點擊按鈕 建立連接


屏幕快照 2016-11-27 下午3.19.34.png
出現搜索設備的彈框,因為GameKit的局限性:

就是搜索設備功能只能搜索到 打開藍牙 運行同一個app并點擊 建立連接按鈕的設備,所以此時我們運行在模擬器上的demo會一直處于搜索設備的狀態

那么,我們把項目運行到真機上:讓真機和模擬器進行數據傳遞。左邊是真機,右邊是模擬器。


屏幕快照 2016-11-27 下午9.11.00.png
  • 此時,兩邊都點擊建立連接


    屏幕快照 2016-11-27 下午9.12.57.png
屏幕快照 2016-11-27 下午9.13.19.png

這時候我們就可就可以點擊模擬器上搜索到的iPhone,或者點擊真機上搜索到的MacBookAir,進行數據傳遞了。

4.設置傳遞的數據,這里我們設置一張圖片到imageView上,首先給imageView添加手勢,點擊imageView打開相冊,選擇相冊一張圖片后把此圖設置到imageView上顯示。

  • 添加手勢
 UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tapaction)];
        [_imageView addGestureRecognizer:tap];
  • 實現手勢調用方法,并簽署相冊協議<UINavigationControllerDelegate,UIImagePickerControllerDelegate>
-(void)tapaction{
    // 判斷是否支持相冊選擇
    if (![UIImagePickerController isSourceTypeAvailable:UIImagePickerControllerSourceTypePhotoLibrary]) {
        NSLog(@"木有相冊");
        return;
    }
//創建選擇相片的控制器
    UIImagePickerController *pic = [[UIImagePickerController alloc]init];
    pic.sourceType = UIImagePickerControllerSourceTypePhotoLibrary;
    pic.delegate = self;
    [self presentViewController:pic animated:YES completion:nil];
}
  • 實現相冊代理方法
    <pre>
    // 圖片選擇完之后調用的方法
    -(void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary<NSString *,id> *)info{

    [picker dismissViewControllerAnimated:YES completion:nil];
    NSLog(@"%s,line = %d,info = %@",func,LINE,info);
    //把圖片設置到imageView上顯示
    self.imageView.image = info[UIImagePickerControllerOriginalImage];

}
</pre>
5.實現點擊 發送按鈕方法 sendBtn;//發送數據

-(void)sendBtnAction{
    //第一步判斷要發送的數據是否存在
    if (!self.imageView.image) return;
    // 發送數據
//    [self.session sendData:UIImagePNGRepresentation(self.imageView.image) toPeers:<#(NSArray *)#>//已經連接的所有設備
//              withDataMode:<#(GKSendDataMode)#> error:<#(NSError *__autoreleasing *)#>]
    NSError *error = nil;
  BOOL sendState = [self.session sendDataToAllPeers:UIImagePNGRepresentation(self.imageView.image)
                        withDataMode:GKSendDataReliable//GKSendDataReliable可靠地傳輸方式,慢,不會丟包,直到傳完,傳遞的信息完整;GKSendDataUnreliable快,丟包,可能傳不完,信息可能不完整
                               error:&error];
    if (!sendState) {
        NSLog(@"%@",error.localizedDescription);
    }
}

6.處理數據傳遞,實現代理方法

#pragma mark - GKPeerPickerControllerDelegate
//最長用的方法,已經成功連接到某個設備,并且開啟了連接會話
- (void)peerPickerController:(GKPeerPickerController *)picker //搜索框
              didConnectPeer:(NSString *)peerID //設備id,連接的設備
    toSession:(GKSession *)session  //連接會話,通過會話可以通過數據傳輸
{

    NSLog(@"%s,line = %d",__func__,__LINE__);
//   1. 首先讓搜索彈框消失
    [picker dismiss];
    
// 2. 記錄會話信息
    self.session = session;
// 3.傳輸數據
    
    //4.設置接收數據,設置完接受者之后,接收數據會觸發方法receiveData:(NSData *)data fromPeer:(NSString *)peer inSession:(GKSession *)session context:(void *)context 現在蘋果已經把這個方法干掉,就是告訴用戶不要用這個框架了;現在我們只是了解學習
    [self.session setDataReceiveHandler:self withContext:nil];  
}
// 設置接收數據,設置完接受者之后,接收數據會觸發此方法,現在蘋果已經把此方法干掉,就是告訴用戶不要用這個框架了;現在我們只是了解學習
- (void)receiveData:(NSData *)data//數據
           fromPeer:(NSString *)peer//來自哪個設備
          inSession:(GKSession *)session//連接會話
            context:(void *)context//
{
    NSLog(@"%s,line = %d,data = %@,peer = %@,session = %@",__func__,__LINE__,data,peer,session);
    // 將接收的數據展示在屏幕上
    self.imageView.image = [UIImage imageWithData:data];
    

}

ok ,可以真機與模擬器之間相互傳遞數據了

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,106評論 6 542
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,441評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,211評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,736評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,475評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,834評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,829評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,009評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,559評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,306評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,516評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,038評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,728評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,132評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,443評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,249評論 3 399
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,484評論 2 379

推薦閱讀更多精彩內容