iOS MultipeerConnectivity 编程发送图片客户端

原创 2015年07月08日 15:50:35

//

//  ViewController.m

//  070803blueclient

//

//  Created by tianshangrenjian on 15/7/8.

//  Copyright © 2015 tianshangrenjian. All rights reserved.

//


#import "ViewController.h"

#import <MultipeerConnectivity/MultipeerConnectivity.h>


@interface ViewController ()<MCSessionDelegate,UIImagePickerControllerDelegate,UINavigationControllerDelegate,MCBrowserViewControllerDelegate>

@property (weak, nonatomic) IBOutlet UIImageView *imgView;


@property (strong,nonatomic) MCSession *session;

@property (strong,nonatomic) UIImagePickerController *imgPc;

@property (strong,nonatomic) MCBrowserViewController *browser;





- (IBAction)btnFind:(id)sender;

- (IBAction)btnSelect:(id)sender;


@end


@implementation ViewController


- (void)viewDidLoad {

    [super viewDidLoad];

    // Do any additional setup after loading the view, typically from a nib.

    MCPeerID *peer=[[MCPeerID alloc] initWithDisplayName:@"sch-client"];

    MCSession *session=[[MCSession alloc] initWithPeer:peer];

    session.delegate=self;

    self.session=session;

    

    

    

}


- (void)didReceiveMemoryWarning {

    [super didReceiveMemoryWarning];

    // Dispose of any resources that can be recreated.

}


- (IBAction)btnFind:(id)sender {

    

    MCBrowserViewController *browser=[[MCBrowserViewController alloc] initWithServiceType:@"sch-server" session:self.session];

    self.browser=browser;

    browser.delegate=self;

    [self presentViewController:browser animated:YES completion:nil];

    

    

    

}


- (void)browserViewControllerDidFinish:(nonnull MCBrowserViewController *)browserViewController

{

    NSLog(@"select finded!");

    [browserViewController dismissViewControllerAnimated:YES completion:nil];

    

}

- (void)browserViewControllerWasCancelled:(nonnull MCBrowserViewController *)browserViewController

{

    NSLog(@"cancel select");

    

    [browserViewController dismissViewControllerAnimated:YES completion:nil];

}

- (IBAction)btnSelect:(id)sender {

    UIImagePickerController *iPc=[[UIImagePickerController alloc] init];

    self.imgPc=iPc;

    self.imgPc.delegate=self;

    [self presentViewController:self.imgPc animated:YES completion:nil];

    

}


- (void)imagePickerController:(nonnull UIImagePickerController *)picker didFinishPickingMediaWithInfo:(nonnull NSDictionary<NSString *,id> *)info

{

    UIImage *img=info[UIImagePickerControllerOriginalImage];

    self.imgView.image=img;

    NSData *data=UIImagePNGRepresentation(img);

    [self.session sendData:data toPeers:[self.session connectedPeers] withMode:MCSessionSendDataUnreliable error:nil];

    NSLog(@"begin send img...");

    [picker dismissViewControllerAnimated:YES completion:nil];

}

- (void)imagePickerControllerDidCancel:(nonnull UIImagePickerController *)picker

{

    [picker dismissViewControllerAnimated:YES completion:nil];

}













// Remote peer changed state.

- (void)session:(MCSession *)session peer:(MCPeerID *)peerID didChangeState:(MCSessionState)state

{

    switch (state) {

        case MCSessionStateConnecting:

            NSLog(@"connectiing!");

            break;

        case MCSessionStateConnected:

            NSLog(@"connected!");

        default:

            break;

    }

}


// Received data from remote peer.

- (void)session:(MCSession *)session didReceiveData:(NSData *)data fromPeer:(MCPeerID *)peerID

{

    NSLog(@"receive data");

    UIImage *img=[UIImage imageWithData:data];

    self.imgView.image=img;

}


// Received a byte stream from remote peer.

- (void)    session:(MCSession *)session

   didReceiveStream:(NSInputStream *)stream

           withName:(NSString *)streamName

           fromPeer:(MCPeerID *)peerID

{

    

}


// Start receiving a resource from remote peer.

- (void)                    session:(MCSession *)session

  didStartReceivingResourceWithName:(NSString *)resourceName

                           fromPeer:(MCPeerID *)peerID

                       withProgress:(NSProgress *)progress

{

    

}


// Finished receiving a resource from remote peer and saved the content

// in a temporary location - the app is responsible for moving the file

// to a permanent location within its sandbox.

- (void)                    session:(MCSession *)session

 didFinishReceivingResourceWithName:(NSString *)resourceName

                           fromPeer:(MCPeerID *)peerID

                              atURL:(NSURL *)localURL

                          withError:(NSError *)error

{

    

}



@end


版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

编写一个服务端可以给多个客户端发送图片

package cn.itcast.tcp;import java.io.FileInputStream; import java.io.FileNotFoundException; import j...

socket编程--客户端发送文件至服务端

这是之前做过的一个笔试题,最近闲来无事,动手试着写了一下,发现自己对IO流的使用还是不够,仍需加强!!! 题干:要求一个客户端通过socket编程将本地的一个文件发送到服务端,服务端接收完毕后退出程序

精选:深入理解 Docker 内部原理及网络配置

网络绝对是任何系统的核心,对于容器而言也是如此。Docker 作为目前最火的轻量级容器技术,有很多令人称道的功能,如 Docker 的镜像管理。然而,Docker的网络一直以来都比较薄弱,所以我们有必要深入了解Docker的网络知识,以满足更高的网络需求。

iOS网络编程之Socket(客户端)

一,iOS网络编程层次模型 在前文《深入浅出Cocoa之Bonjour网络编程》中我介绍了如何在Mac系统下进行 Bonjour 编程,在那篇文章中也介绍过 Cocoa 中网络编程层次结构分...

HTTPS 客户端发送请求(三)

HTTPS 请求不忽略证书方式 加载原始keystore方式 在第一章中我们生成了一张证书,并放在了c://tomcat.keystore下,我们就使用这个证书来完成请求 package ...

JavaMail简单客户端邮件发送

使用qq邮箱服务器,实现简单邮件发送功能。 一、设置qq邮箱账号 该账号作为邮件的发送账号。设置操作:进入到QQ邮箱,设置--账号,找到POP3/SMTP服务进行开启。 二、下载javamail.j...

HTTPS 客户端发送请求(二)

https 完整web开发 Tomcat 6.0 配置 1、生成安全访问的证书。 命令行下执行:keytool -genkey -alias tomcat -keyalg RSA -keys...

socket客户端发送信息举例

import java.io.InputStream; import java.io.OutputStream; import java.net.Socket; import java.nio.cha...

HTTPS 客户端发送请求(四)

HTTP与HTTPS灵活转换请求 前言:在工作中我们可能不一定只用到https和http,有时候可能两者都会用到,那我们发送了一个连接的时候呢,我们如何灵活的转换两者的请求呢,此时我...

Android Tcp客户端发送数据

Problems & Solutions1、NetworkOnMainThreadException不能直接在主界面线程中创建Socket。需要将其放在子线程中执行。 LogCat报错信息如下FAT...

activemq发送客户端(封装)

1、在pom中引入   cn.activemq.client   activemqclient   1.0 2、添加配置文件 xmlns:xsi="http...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)