本人之前一直想搞搞用cocos进行网络编程,也在网上逛了很久,但令人纳闷的是,网上的大牛们要么讲了些socket编程的原理,要么讲了些cocos2dx,socket的独特之处。但是作为一名菜鸟,能把程序跑起来,是最基本的一步,也是对自信心一个很大的鼓励。在网上找了很久,都 没有一整套完整的源码。小弟不才,自我摸索,搞了一个简单的TCP/IP协议的简单连接。

学习之些,对socket总得有一个基本的了解吧,此内容不少,给出一个别人的博客链接,大家可以先看看这篇博客。

socket基础学习

要进行socket编程,首先要有socket包,点击下载。该包是从别人来下载过来,别人已经封装好了,在windows下和linux下都能运行。

看完上面所给的博客后。我贴上我的代码。理工科,文章写得不好,尽量少费话,直接上代码。

客户端:

------------------------------------

#ifndef __Client_SCENE_H__
#define __Client_SCENE_H__


#include "cocos2d.h"
#include "ODSocket/ODSocket.h"
USING_NS_CC;
enum GameState
{
GameState_init,
GameState_finishset,
GameState_null,
};
class Client : public cocos2d::Layer
{
public:


static cocos2d::Scene* createScene();


virtual bool init();

bool onTouchBegan(Touch* touch,Event *event);
void onTouchEnded(Touch* touch,Event *event);


void update(float dt);
void menuCloseCallback(cocos2d::Ref* pSender);

CREATE_FUNC(Client);


void connectServer(const char * ip,int port);


void connectServer(const char * ip,int port,const char* _infodata);


void receiveData();


void SelectCallback1(Ref* pSender);
void SelectCallback2(Ref* pSender);
void SelectCallback3(Ref* pSender);
void SelectCallback4(Ref* pSender);
void SelectCallback5(Ref* pSender);
private:
ODSocket m_socket;


cocos2d::TextFieldTTF* textEdit;


GameState m_gamestate;
bool m_setok;
};


#endif // __Client_SCENE_H__

--------------------------------------------------------------------------------

#include "HelloWorldScene.h"


USING_NS_CC;
using namespace std;


static const char* C_select[]=
{
"a","b","c","d"
};
static const int C_selectNum = 4;


Scene* Client::createScene()
{
auto scene = Scene::create();

auto layer = Client::create();


scene->addChild(layer);


return scene;
}


bool Client::init()
{


if ( !Layer::init() )
{
return false;
}

Size visibleSize = Director::getInstance()->getVisibleSize();
Vec2 origin = Director::getInstance()->getVisibleOrigin();
auto closeItem = MenuItemImage::create(
"Closenormal.png",
"CloseSelected.png",
CC_CALLBACK_1(Client::menuCloseCallback,this));

closeItem->setPosition(Vec2(origin.x + visibleSize.width - closeItem->getContentSize().width/2,
origin.y + closeItem->getContentSize().height/2));
auto menu = Menu::create(closeItem,NULL);
menu->setPosition(Vec2::ZERO);
this->addChild(menu,1);


TTFConfig ttfConfig("fonts/arial.ttf",100);


auto label_1 = Label::createWithTTF(ttfConfig,C_select[0]);
auto menuItem_1 = MenuItemLabel::create(label_1,CC_CALLBACK_1(Client::SelectCallback1,this));
menu->addChild(menuItem_1,0);
menuItem_1->setPosition(Vec2(1/5.0*visibleSize.width,400));


auto label_2 = Label::createWithTTF(ttfConfig,C_select[1]);
auto menuItem_2 = MenuItemLabel::create(label_2,CC_CALLBACK_1(Client::SelectCallback2,this));
menu->addChild(menuItem_2,0);
menuItem_2->setPosition(Vec2(2/5.0*visibleSize.width,400));


auto label_3 = Label::createWithTTF(ttfConfig,C_select[2]);
auto menuItem_3 = MenuItemLabel::create(label_3,CC_CALLBACK_1(Client::SelectCallback3,this));
menu->addChild(menuItem_3,0);
menuItem_3->setPosition(Vec2(3/5.0*visibleSize.width,400));


auto label_4 = Label::createWithTTF(ttfConfig,C_select[3]);
auto menuItem_4 = MenuItemLabel::create(label_4,CC_CALLBACK_1(Client::SelectCallback4,this));
menu->addChild(menuItem_4,0);
menuItem_4->setPosition(Vec2(4/5.0*visibleSize.width,400));


auto label_5 = Label::createWithTTF("ok","fonts/arial.ttf",30);
auto menuItem_5 = MenuItemLabel::create(label_5,CC_CALLBACK_1(Client::SelectCallback5,this));
menu->addChild(menuItem_5,0);
menuItem_5->setPosition(Vec2(400,100));



textEdit = CCTextFieldTTF::textFieldWithPlaceHolder("Please input ip:",
"Arial",30);

//设置文本框的位置
textEdit->setPosition(Vec2(100,100));
//添加文本框到层上
this->addChild(textEdit);


//当触摸到控件的时候弹出软键盘
setTouchMode(kCCtouchesOneByOne);
auto listener = EventListenerTouchOneByOne::create();
listener->onTouchBegan = CC_CALLBACK_2(Client::onTouchBegan,this);
listener->onTouchEnded = CC_CALLBACK_2(Client::onTouchEnded,this);
auto _eventdispatcher=Director::getInstance()->getEventdispatcher();
_eventdispatcher->addEventListenerWithSceneGraPHPriority(listener,this);


m_gamestate = GameState_init;
m_setok = false;
this->scheduleUpdate();


//connectServer("127.0.0.1",9999,"client");
return true;
}
bool Client::onTouchBegan(Touch* touch,Event *event)
{
auto point=touch->getLocation();
if (textEdit->getBoundingBox().containsPoint(point) == true && m_gamestate == GameState_init)
{
textEdit->attachWithIME();
}
return true;
}


void Client::onTouchEnded(Touch* touch,Event *event)
{

}


void Client::update(float dt)
{
switch (m_gamestate)
{
case GameState_init:
if (m_setok == true )
{
m_gamestate=GameState_finishset;
string m_text = textEdit->getString();
connectServer(m_text.c_str(),"client");
log("----------------------------------------input id is %s",m_text.c_str());
}
break;
case GameState_finishset:


m_gamestate=GameState_null;
break;
case GameState_null:
break;
default:
break;
}
}


void Client::connectServer(const char * ip,const char* _infodata)
{
// 初始化
m_socket.Init();
m_socket.Create(AF_INET,SOCK_STREAM,0);
// 设置服务器的IP地址,端口号
bool result = m_socket.Connect(ip,port);

if (result)
{
// 发送数据 Send
log("%s connect to server success!",_infodata);
// 开启新线程,在子线程中,接收数据
//m_socket.Send(_infodata,11);
//std::thread recvThread = std::thread(&HelloWorld::receiveData,this);
//recvThread.detach(); // 从主线程分离
//receiveData();
}
else
{
log("%s can not connect to server",_infodata);
return;
}
//m_socket.Close();
}


// 客户接收数据
void Client::receiveData()
{
// 因为是强联网,所以可以一直检测服务端是否有数据传来
while (true)
{
// 接收数据 Recv
char data[512] = "";
int result = m_socket.Recv(data,512,0);
//log("%d",result);
// 与服务器的连接断开了
if (result <= 0)
break;


log("client receive:%s",data);
}
// 关闭连接
m_socket.Close();
}


void Client::menuCloseCallback(Ref* pSender)
{
#if (CC_TARGET_PLATFORM == CC_PLATFORM_WP8) || (CC_TARGET_PLATFORM == CC_PLATFORM_WINRT)
MessageBox("You pressed the close button. Windows Store Apps do not implement a close button.","Alert");
return;
#endif


Director::getInstance()->end();


#if (CC_TARGET_PLATFORM == CC_PLATFORM_IOS)
exit(0);
#endif
}


void Client::SelectCallback1(Ref* pSender)
{
m_socket.Send(C_select[0],1);
}


void Client::SelectCallback2(Ref* pSender)
{
m_socket.Send(C_select[1],1);
}


void Client::SelectCallback3(Ref* pSender)
{
m_socket.Send(C_select[2],1);
}


void Client::SelectCallback4(Ref* pSender)
{
m_socket.Send(C_select[3],1);
}


void Client::SelectCallback5(Ref* pSender)
{
m_setok =true ;
}

------------------------------------------------------------------------

服务器

#ifndef __HELLOWORLD_SCENE_H__
#define __HELLOWORLD_SCENE_H__


#include "cocos2d.h"
#include "ODSocket/ODSocket.h"
USING_NS_CC;
enum game_state
{
game_state_init,
game_state_getnext,
gam_state_null,
};


class HelloWorld : public cocos2d::Layer
{
public:
static cocos2d::Scene* createScene(int _id);


virtual bool init(int _id);


static HelloWorld* create(int id);


void menuCloseCallback(cocos2d::Ref* pSender);


void connectServer(const char * ip,int port);


void receiveData();


void server();


void update(float delta);


void getNext(Ref* _sender);
void startServer();
void stopServer();
private:
Label* m_label;
Label* m_result;
ODSocket m_ServerSocket;
game_state m_gamestate;
std::string m_recData;
};


#endif // __HELLOWORLD_SCENE_H__

-----------------------------------------------------------------

#include "HelloWorldScene.h"


USING_NS_CC;
using namespace std;
static const char* C_select[]=
{
"a","d",
};
static std::string _currentShowData="nothing";


Scene* HelloWorld::createScene(int id)
{
// 'scene' is an autorelease object
auto scene = Scene::create();

// 'layer' is an autorelease object
auto layer = HelloWorld::create(id);


// add layer as a child to scene
scene->addChild(layer);


// return the scene
return scene;
}


HelloWorld* HelloWorld::create(int id)
{
HelloWorld* _layer = new HelloWorld();
if (_layer && _layer->init(id))
{
_layer->autorelease();
return _layer;
}else
{
delete _layer;
_layer =nullptr;
return _layer;
}

}


bool HelloWorld::init(int id)
{


if ( !Layer::init() )
{
return false;
}
m_recData = "";
Size visibleSize = Director::getInstance()->getVisibleSize();
Vec2 origin = Director::getInstance()->getVisibleOrigin();


auto closeItem = MenuItemImage::create(
"Closenormal.png",
CC_CALLBACK_1(HelloWorld::menuCloseCallback,
origin.y + closeItem->getContentSize().height/2));




auto menu = Menu::create(closeItem,NULL);
menu->setPosition(Vec2::ZERO);
this->addChild(menu,1);


auto next= Label::createWithTTF("next",50);
auto menuItem_1 = MenuItemLabel::create(next,CC_CALLBACK_1(HelloWorld::getNext,0);
menuItem_1->setPosition(Vec2(4/5.0*visibleSize.width,100));


TTFConfig ttfConfig("fonts/arial.ttf",100);
m_label = Label::createWithTTF(ttfConfig,"");
m_label->setPosition(Vec2(visibleSize.width/2,visibleSize.height/2));
this->addChild(m_label,1);



m_result = Label::createWithTTF("",50);
m_result->setPosition(Vec2(visibleSize.width/2,visibleSize.height/4));
this->addChild(m_result,1);
m_result->setColor(Color3B(255,0));


m_gamestate = game_state_init;
this->scheduleUpdate();



return true;
}


void HelloWorld::update(float delta)
{
std::thread recvThread;
switch (m_gamestate)
{
case game_state_init:
startServer();
m_gamestate=game_state_getnext;
break;
case game_state_getnext:

recvThread = std::thread(&HelloWorld::server,this);
recvThread.detach();
m_gamestate=gam_state_null;
break;
case gam_state_null:
if (m_recData == _currentShowData)
{
m_result->setString("true");
}
else
{
m_result->setString("false");
}
break;
default:
break;
}
}


void HelloWorld::startServer()
{
log("server init !");
m_ServerSocket.Init();
m_ServerSocket.Create(AF_INET,0);
m_ServerSocket.Bind(9999);
m_ServerSocket.Listen(5);
}


void HelloWorld::stopServer()
{
m_ServerSocket.Close();
}


void HelloWorld::getNext(Ref* _sender)
{


_currentShowData= C_select[rand()%4];
m_label->setString(_currentShowData);
//m_gamestate=game_state_getnext;


}


void HelloWorld::server()
{

m_ServerSocket.Accept(m_ServerSocket);
log("server is ready !");
while (true)
{
char data[512] = "";
int result =m_ServerSocket.Recv(data,0 );


log("server receive:%s",data);
m_recData=data;
if (result<0)
{
break;
}

//m_ServerSocket.Send("helloclient",11);
}
//stopServer();
}


void HelloWorld::menuCloseCallback(Ref* pSender)
{
#if (CC_TARGET_PLATFORM == CC_PLATFORM_WP8) || (CC_TARGET_PLATFORM == CC_PLATFORM_WINRT)
MessageBox("You pressed the close button. Windows Store Apps do not implement a close button.","Alert");
return;
#endif


Director::getInstance()->end();


#if (CC_TARGET_PLATFORM == CC_PLATFORM_IOS)
exit(0);
#endif
}

----------------------------------------

上面主要是是socket编程中的TCP/IP,UDP正在更新中,尽请期待。。。。。

cocos2d-x-3.5 socket编程的更多相关文章

  1. html5 http的轮询和Websocket原理

    这篇文章主要介绍了html5 http的轮询和Websocket原理的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. HTML5、Select下拉框右边加图标的实现代码(增进用户体验)

    这篇文章主要介绍了HTML5、Select下拉框右边加图标的实现代码,深度美化页面增进用户体验效果,需要的朋友可以参考下

  3. 在Sierra上,Brew安装错误单独使用Xcode是不够的

    我正在尝试使用HomeBrewv1.3.8在运行xCodev9.1的MacOSXSerrav10.12.6上安装软件包.安装和错误是然后我运行命令表示软件更新服务器无法使用命令行工具包.我进入xCode,它表明安装了命令行工具.任何帮助将非常感激.西奥解决方法我去了AppleDeveloper网站并直接下载了命令行工具dmg.首先需要设置Apple帐户.命令行工具可在以下位置找到–https://

  4. iOS 10 Safari问题在DOM中不再包含元素

    使用此链接,您可以重现该错误.https://jsfiddle.net/pw7e2j3q/如果您点击元素并从dom中删除它,然后单击链接测试.你应该看到旧的元素弹出选择.是否有一些黑客来解决这个问题?解决方法我能够重现这个问题.问题是,每当您尝试删除其更改事件上的选择框时,iOS10都无法正确解除对选择框的绑定.要解决此问题,您需要将代码更改事件代码放在具有一些超时

  5. iOS Chrome上的HTML SELECT不显示“完成”选项

    我们在iOS上的Chrome中使用UI呈现时遇到问题,特别是HTMLSELECTDropDown元素.例:使用Safari,当您点击SELECT时,屏幕底部会打开一个微调器–您可以点击完成以选择您的选择并返回到表单.但是,当您在iOS上的Chrome中加载完全相同的页面时,不会显示“完成”.用户必须选择他们的选择,然后点击UI上的其他位置返回到表单.非常不直观,用户感觉好像SELECT没有用.有人有解决方案吗?

  6. 安装命令行工具Xcode 5

    我已经尝试过并尝试过但我仍然无法解决问题.我正在尝试安装PebbleSDK1.12并安装Xcode5的命令行工具.每次我在终端尝试xcode-select–install时,我都会收到“无法安装软件,因为它目前在软件更新服务器中不可用”我试图重新安装Xcode,但是没有用.当我进入Xcode-preferences-downloads时,没有命令行工具的部分.我也试过从开发者网站安装它们但无济于事.下载看起来正确,然后我去Xcode看到首选项,并没有列出命令行工具.你们都能提出什么建议吗?

  7. ios – xcodebuild相当于Xcode的“产品&gt;构建&gt;测试”

    我正在尝试编写一个脚本,将iOS应用程序提交给AppThwack(一个“真正的设备”UI测试服务).他们的指导是使用XcodeGUI,并使用BuildFor>Xcode产品菜单中的测试选项.这是有效的,但我无法将其转换为xcodebuild等效项.更一般地说,我们如何确定Xcode传递给xcodebuild的什么参数(假设它使用该工具).解决方法现在可以从Xcode8开始(在写作时在beta版).

  8. xcode – 在REPL中创建目标Swift AST上下文时出错((null))

    在这里,我已经看到有关这个错误的几个的问题,但是没有一个提出的解决方案适用于我.这是我得到的这可能是也可能没有发生在我发出一些我不记得的命令之后.奇怪的是,如果我卸载Xcode,REPL开始正常工作.但是,如果我重新安装Xcode,错误就会回来.我在Xcode7.2.1,顺便说一句.思考?

  9. ios – Swift:使用GCDAsyncUdpSocket接收UDP

    开始:接收:发送:编辑:添加了忘记的代码行.解决方法我终于得到它使用这个套接字设置:

  10. IOS设备问题与HTML表单输入(type = text)

    所以我有一个HTML登录表单与两个字段:电子邮件和密码.这些可以在除iOS设备之外的任何设备的浏览器上轻松填充.在IOS领域几乎不能关注焦点,一旦焦点,键盘弹出,我开始打字,但实际上没有填充.我已经尝试过Chrome和safari,仍然得到相同的结果.字段保持黑色.Bellow是我的格式如何格式化:请帮助!

随机推荐

  1. 【cocos2d-x 3.x 学习笔记】对象内存管理

    Cocos2d-x的内存管理cocos2d-x中使用的是上面的引用计数来管理内存,但是又增加了一些自己的特色。cocos2d-x中通过Ref类来实现引用计数,所有需要实现内存自动回收的类都应该继承自Ref类。下面是Ref类的定义:在cocos2d-x中创建对象通常有两种方式:这两中方式的差异可以参见我另一篇博文“对象创建方式讨论”。在cocos2d-x中提倡使用第二种方式,为了避免误用第一种方式,一般将构造函数设为protected或private。参考资料:[1]cocos2d-x高级开发教程2.3节[

  2. 利用cocos2dx 3.2开发消灭星星六如何在cocos2dx中显示中文

    由于编码的不同,在cocos2dx中的Label控件中如果放入中文字,往往会出现乱码。为了方便使用,我把这个从文档中获取中文字的方法放在一个头文件里面Chinese.h这里的tex_vec是cocos2dx提供的一个保存文档内容的一个容器。这里给出ChineseWords,xml的格式再看看ChineseWord的实现Chinese.cpp就这样,以后在需要用到中文字的地方,就先include这个头文件然后调用ChineseWord函数,获取一串中文字符串。

  3. 利用cocos2dx 3.2开发消灭星星七关于星星的算法

    在前面,我们已经在GameLayer中利用随机数初始化了一个StarMatrix,如果还不知道怎么创建星星矩阵请回去看看而且我们也讲了整个游戏的触摸事件的派发了。

  4. cocos2dx3.x 新手打包APK注意事项!

    这个在编译的时候就可以发现了比较好弄这只是我遇到的,其他的以后遇到再补充吧。。。以前被这两个问题坑了好久

  5. 利用cocos2dx 3.2开发消灭星星八游戏的结束判断与数据控制

    如果你看完之前的,那么你基本已经拥有一个消灭星星游戏的雏形。开始把剩下的两两互不相连的星星消去。那么如何判断是GameOver还是进入下一关呢。。其实游戏数据贯穿整个游戏,包括星星消除的时候要加到获得分数上,消去剩下两两不相连的星星的时候的加分政策等,因此如果前面没有做这一块的,最好回去搞一搞。

  6. 利用cocos2dx 3.2开发消灭星星九为游戏添加一些特效

    needClear是一个flag,当游戏判断不能再继续后,这个flag变为true,开始消除剩下的星星clearSumTime是一个累加器ONE_CLEAR_TIME就是每颗星星消除的时间2.连击加分信息一般消除一次星星都会有连击信息和加多少分的信息。其实这些combo标签就是一张图片,也是通过控制其属性或者runAction来实现。源码ComboEffect.hComboEffect.cpp4.消除星星粒子效果消除星星时,为了实现星星爆裂散落的效果,使用了cocos2d提供的粒子特效引擎对于粒子特效不了

  7. 02 Cocos2D-x引擎win7环境搭建及创建项目

    官网有搭建的文章,直接转载记录。环境搭建:本文介绍如何搭建Cocos2d-x3.2版本的开发环境。项目创建:一、通过命令创建项目前面搭建好环境后,怎样创建自己的Cocos2d-x项目呢?先来看看Cocos2d-x3.2的目录吧这就是Cocos2d-x3.2的目录。输入cocosnew项目名–p包名–lcpp–d路径回车就创建成功了例如:成功后,找到这个项目打开proj.win32目录下的Hello.slnF5成功了。

  8. 利用cocos2dx 3.2开发消灭星星十为游戏添加音效项目源码分享

    一个游戏,声音也是非常的重要,其实cocos2dx里面的简单音效引擎的使用是非常简单的。我这里只不过是用一个类对所有的音效进行管理罢了。Audio.hAudio.cpp好了,本系列教程到此结束,第一次写教程如有不对请见谅或指教,谢谢大家。最后附上整个项目的源代码点击打开链接

  9. 03 Helloworld

    程序都有一个入口点,在C++就是main函数了,打开main.cpp,代码如下:123456789101112131415161718#include"main.h"#include"AppDelegate.h"#include"cocos2d.h"USING_NS_CC;intAPIENTRY_tWinMain{UNREFERENCED_ParaMETER;UNREFERENCED_ParaMETER;//createtheapplicationinstanceAppDelegateapp;return

  10. MenuItemImage*图标菜单创建注意事项

    学习cocos2dx,看的是cocos2d-x3.x手游开发实例详解,这本书错误一大把,本着探索求知勇于发现错误改正错误的精神,我跟着书上的例子一起调试,当学习到场景切换这个小节的时候,出了个错误,卡了我好几个小时。

返回
顶部