public static int SendGpPutt(TplayInfo putt) { PGLog.LOGI("TcpApp::SendGpPutt"); TcpCln pNet = TcpApp.GetMainNet(); int hr = 0; ushort opp = NTC.CS_REQ_BROADCAST; // op protocol ushort gpp = NTC.GP_PLAY_PUTT; // game play protocol m_wrkPck.Reset(); m_wrkPck.AddData(gpp); m_wrkPck.AddData(TcpApp.app_user_id); m_wrkPck.AddData(TcpApp.app_oppo_id); m_wrkPck.AddData(putt.x); m_wrkPck.AddData(putt.y); m_wrkPck.AddData(putt.z); m_wrkPck.AddData(putt.z); m_wrkPck.AddData(putt.c_y); m_wrkPck.AddData(putt.club); m_wrkPck.AddData(putt.pow); m_wrkPck.EnCode(opp); hr = pNet.Send(m_wrkPck); return(hr); }
protected int AddNewClient(Socket scH) { if (NTC.MAX_CONNECT <= m_vCln.Count) { return(NTC.EFAIL); } EndPoint sdH = scH.RemoteEndPoint; uint netId = PGN.Packet.SocketId(ref scH); TcpCln pCln = new TcpCln(netId); pCln.Create(this, scH, sdH); //string guid = Guid.NewGuid().ToString().ToUpper(); string crpKey = netId.ToString() + " PGN_ENCRYPTION_KEY_BYTE_STRING"; PGLog.LOGI("AddNewClient::" + crpKey); pCln.Send(crpKey, NTC.GP_DEFAULT); m_vCln.Add(pCln); pCln.Recv(); return(NTC.OK); }
public static int SendStop() { PGLog.LOGI("TcpApp::SendStop"); TcpCln pNet = TcpApp.GetMainNet(); int hr = 0; ushort opp = NTC.CS_REQ_STOP; m_wrkPck.Reset(); m_wrkPck.EnCode(opp); hr = pNet.Send(m_wrkPck); return(hr); }
public static int SendGo() { int hr = 0; PGLog.LOGI("TcpApp::SendGo"); //TcpCln pNet = TcpApp.GetMainNet(); //ushort opp = NTC.CS_REQ_GO; //m_wrkPck.Reset(); //m_wrkPck.EnCode(opp); //hr = pNet.Send(m_wrkPck); return(hr); }
public static int SendReady(byte bReady) { PGLog.LOGI("TcpApp::SendReady"); TcpCln pNet = TcpApp.GetMainNet(); int hr = 0; ushort opp = NTC.CS_REQ_READY; m_wrkPck.Reset(); m_wrkPck.AddData(bReady); m_wrkPck.EnCode(opp); hr = pNet.Send(m_wrkPck); return(hr); }
public static void IoDefEvent(int ev, int err, object socket, object data) { switch (ev) { case NTC.EV_CLOSE: PGLog.LOGI("IoEvent: Close"); break; case NTC.EV_ACCEPT: PGLog.LOGI("IoEvent: Accept"); break; case NTC.EV_CONNECT: PGLog.LOGI("IoEvent: Connect"); break; case NTC.EV_SEND: PGLog.LOGI("IoEvent: Send"); break; case NTC.EV_RECV: PGLog.LOGI("IoEvent: Receive"); break; default: PGLog.LOGI("IoEvent: Not defined"); break; } }
protected void RemoveClient(TcpBase v) { int n = m_vCln.FindIndex(_cln => _cln.GetSocket() == v.GetSocket()); if (0 > n) { return; } uint key = m_vCln[n].NetId; m_vCln[n].Destroy(); m_vCln.RemoveAt(n); PGLog.LOGI("RemoveClient::[" + n + "]: " + key + ", Remain Client :" + m_vCln.Count); }
protected void IoSend(IAsyncResult iar) { int hr = NTC.OK; TcpCln pCln = (TcpCln)iar.AsyncState; int sent = -1; try { sent = pCln.m_scH.EndSend(iar); } catch (SocketException e0) { PGLog.LOGW("IoSend::SocketException::" + e0.ToString()); hr = NTC.EFAIL_SOCK; goto ERR; } catch (Exception e1) { PGLog.LOGW("IoSend::Exception::" + e1.ToString()); hr = NTC.EFAIL; goto ERR; } if (pCln != this) { PGLog.LOGW("IoSend::Different object"); hr = NTC.EFAIL; goto ERR; } PGLog.LOGI("IoSend::Success::Sending byte::" + sent); lock (m_oLock) { m_sndC = NTC.OK; IoEvent(NTC.EV_SEND, hr, pCln.m_scH, 0, this); } return; ERR: lock (m_oLock) { IoEvent(NTC.EV_SEND, hr, pCln.m_scH, 0, this); } }
public static int IoDef(int ev, int hr, object socket, int len, object data) { switch (ev) { case NTC.EV_CLOSE: PGLog.LOGI("IoDef: Close"); break; case NTC.EV_ACCEPT: PGLog.LOGI("IoDef: Accept"); break; case NTC.EV_CONNECT: PGLog.LOGI("IoDef: Connect"); break; case NTC.EV_SEND: PGLog.LOGI("IoDef: Send"); break; case NTC.EV_RECV: PGLog.LOGI("IoDef: Receive"); break; default: PGLog.LOGI("IoDef: Not defined"); break; } return(NTC.OK); }
public static int SendRsInvite(uint destId, byte rq) { PGLog.LOGI("TcpApp::SendRsInvite"); TcpCln pNet = TcpApp.GetMainNet(); int hr = 0; ushort opp = NTC.CS_REQ_BROADCAST; // op protocol ushort gpp = NTC.GP_RS_INVITE; // game play protocol m_wrkPck.Reset(); m_wrkPck.AddData(gpp); m_wrkPck.AddData(TcpApp.app_user_id); m_wrkPck.AddData(destId); m_wrkPck.AddData(rq); m_wrkPck.EnCode(opp); hr = pNet.Send(m_wrkPck); return(hr); }
public static int SendGpBallPos(float x, float y, float z) { PGLog.LOGI("TcpApp::SendGpBallPos"); TcpCln pNet = TcpApp.GetMainNet(); int hr = 0; ushort opp = NTC.CS_REQ_BROADCAST; // op protocol ushort gpp = NTC.GP_PLAY_BPOS; // game play protocol m_wrkPck.Reset(); m_wrkPck.AddData(gpp); m_wrkPck.AddData(TcpApp.app_user_id); m_wrkPck.AddData(TcpApp.app_oppo_id); m_wrkPck.AddData(x); m_wrkPck.AddData(y); m_wrkPck.AddData(z); m_wrkPck.EnCode(opp); hr = pNet.Send(m_wrkPck); return(hr); }
//////////////////////////////////////////////////////////////////////// // Inner Process... protected void WorkAcp() { int hr = NTC.OK; try { while (true) { Socket scH = null; scH = m_scH.Accept(); PGLog.LOGI("WorkAcp::New Client::" + scH); lock (m_oLock) { hr = AddNewClient(scH); if (0 > hr) { PGLog.LOGI("WorkAcp::Client List is Full"); } } } } catch (SocketException e0) { PGLog.LOGW("WorkAcp::SocketException::" + e0.ToString()); hr = NTC.EFAIL_SOCK; IoEvnt(NTC.EV_ACCEPT, hr, this.m_scH, 0, this); } catch (Exception e1) { PGLog.LOGW("WorkAcp::Exception::" + e1.ToString()); hr = NTC.EFAIL; IoEvnt(NTC.EV_ACCEPT, hr, this.m_scH, 0, this); } }
public static int SendGpEnd(TplayInfo end) { PGLog.LOGI("TcpApp::SendGpEnd"); TcpCln pNet = TcpApp.GetMainNet(); int hr = 0; ushort opp = NTC.CS_REQ_BROADCAST; // op protocol ushort gpp = NTC.GP_PLAY_END; // game play protocol m_wrkPck.Reset(); m_wrkPck.AddData(gpp); m_wrkPck.AddData(TcpApp.app_user_id); m_wrkPck.AddData(TcpApp.app_oppo_id); m_wrkPck.AddData(end.x); m_wrkPck.AddData(end.y); m_wrkPck.AddData(end.z); m_wrkPck.AddData(end.stroke); m_wrkPck.AddData(end.bonus); m_wrkPck.EnCode(opp); hr = pNet.Send(m_wrkPck); return(hr); }
public static void OnIoEvent(int ev, int hr, object socket, int rcn, object data) { if (NTC.EV_CLOSE == ev) { PGLog.LOGI("OnRecv: gracefully closed"); } else if (NTC.EV_ACCEPT == ev) { PGLog.LOGI("OnRecv: Accept"); } else if (NTC.EV_CONNECT == ev) { PGLog.LOGI("OnRecv: Connect"); if (NTC.OK != hr) { } } else if (NTC.EV_SEND == ev) { PGLog.LOGI("OnRecv: Send"); } else if (NTC.EV_RECV == ev) { PGLog.LOGI("OnRecv: Receive"); byte[] rcv = null; ushort len = 0; ushort opp = 0; int idx_bgn = NTC.PCK_HEAD; int i = 0; if (0 > hr) { PGLog.LOGI("OnRecv: disconnected"); TcpCln pCln = (TcpCln)data; pCln.CloseSocket(); return; } rcv = (byte[])data; len = Packet.LenFromBuf(rcv); opp = Packet.OppFromBuf(rcv); if (NTC.SC_ANS_LOGIN == opp) { byte user_count = 0; app_user_lst.Clear(); app_pmap_lst.Clear(); // setup the user id, and character name Packet.ValueFromBuf(ref app_user_id, rcv, idx_bgn + 0); Packet.ValueFromBuf(ref app_char_name, rcv, idx_bgn + 4, 40); PGLog.LOGI("OnRecv:user id/name::" + app_user_id + ", " + app_char_name); Packet.ValueFromBuf(ref user_count, rcv, idx_bgn + 48); idx_bgn = NTC.PCK_HEAD + 49; for (i = 0; i < user_count; ++i) { uint id = 0; string name = null; byte owner = 0; byte ready = 0; Packet.ValueFromBuf(ref id, rcv, idx_bgn + 46 * i + 0); Packet.ValueFromBuf(ref name, rcv, idx_bgn + 46 * i + 4, 40); Packet.ValueFromBuf(ref owner, rcv, idx_bgn + 46 * i + 44); Packet.ValueFromBuf(ref ready, rcv, idx_bgn + 46 * i + 45); TuserInfo usr = new TuserInfo(id, name, owner, ready); app_user_lst.Add(usr); PGLog.LOGI("OnRecv:NTC.SC_ANS_LOGIN:: id/name::" + id + ", " + name); } for (i = 0; i < 3; ++i) { uint id = (uint)i; string name = "map " + i; TplayMap map = new TplayMap(id, name); app_pmap_lst.Add(map); } // change the phase of the application Program.ChageForm(APC.PHASE_LOBBY); } else if (NTC.SC_BROADCAST_USERLIST == opp) { byte user_count = 0; idx_bgn = NTC.PCK_HEAD; app_user_lst.Clear(); Packet.ValueFromBuf(ref user_count, rcv, idx_bgn + 0); idx_bgn = NTC.PCK_HEAD + 1; for (i = 0; i < user_count; ++i) { uint id = 0; string name = null; byte owner = 0; byte ready = 0; Packet.ValueFromBuf(ref id, rcv, idx_bgn + 46 * i + 0); Packet.ValueFromBuf(ref name, rcv, idx_bgn + 46 * i + 4, 40); Packet.ValueFromBuf(ref owner, rcv, idx_bgn + 46 * i + 44); Packet.ValueFromBuf(ref ready, rcv, idx_bgn + 46 * i + 45); TuserInfo usr = new TuserInfo(id, name, owner, ready); app_user_lst.Add(usr); PGLog.LOGI("OnRecv:NTC.SC_ANS_LOGIN:: id/name::" + id + ", " + name); } Program.ChageUserList(0); } else if (NTC.SC_BROADCAST_LOGOUT == opp) { uint id = 0; string name = null; idx_bgn = NTC.PCK_HEAD; Packet.ValueFromBuf(ref id, rcv, idx_bgn + 0); name = TcpApp.FindUser(id).name; for (i = 0; i < app_user_lst.Count; ++i) { if (app_user_lst[i].id == id) { app_user_lst.RemoveAt(i); break; } } Program.ChageUserList(0); PGLog.LOGI("OnRecv:NTC.SC_BROADCAST_LOGOUT::" + name); } else if (NTC.CS_REQ_BROADCAST == opp) { // // GAME PLAY PACKET: gpp + send id + {dest id} + data // idx_bgn = NTC.PCK_HEAD; ushort gpp = 0; uint sendId = 0; uint destId = 0; Packet.ValueFromBuf(ref gpp, rcv, idx_bgn + 0); // 초대 받음 if (NTC.GP_RQ_INVITE == gpp) { uint idx_map = 0; Packet.ValueFromBuf(ref sendId, rcv, idx_bgn + 2); Packet.ValueFromBuf(ref destId, rcv, idx_bgn + 2 + 4); Packet.ValueFromBuf(ref idx_map, rcv, idx_bgn + 2 + 4 + 4); if (TcpApp.app_user_id == destId) { string name = TcpApp.FindUser(sendId).name; int inviteRps = NTC.RST_OK; string log = "OnRecv:NTC.GP_INVITE:: sender:" + name + ", dest id::" + destId + ", map id::" + idx_map; PGLog.LOGI(log); DialogResult r = MessageBox.Show("From " + name + " 한판 뜰래? ", "Inviting", MessageBoxButtons.YesNo); if (DialogResult.No == r) { inviteRps = NTC.RST_NO; } TcpApp.SendRsInvite(sendId, (byte)inviteRps); if (NTC.RST_OK == inviteRps) { app_advr_id = sendId; TcpApp.FindUser(app_user_id).ready = NTC.RST_READY_TRUE; TcpApp.SendReady(NTC.RST_READY_TRUE); } } } // 초대 응답 else if (NTC.GP_RS_INVITE == gpp) { byte rq = 0; Packet.ValueFromBuf(ref sendId, rcv, idx_bgn + 2); Packet.ValueFromBuf(ref destId, rcv, idx_bgn + 2 + 4); Packet.ValueFromBuf(ref rq, rcv, idx_bgn + 2 + 4 + 4); if (TcpApp.app_user_id == destId) { string name = TcpApp.FindUser(sendId).name; string log = "OnRecv:NTC.GP_RS_INVITE::" + name + "::" + rq; PGLog.LOGI(log); // Send Ready if (rq == NTC.RST_OK) { app_advr_id = sendId; MessageBox.Show("Inviting success", "Msg", MessageBoxButtons.OK); TcpApp.SendReady(NTC.RST_READY_TRUE); return; } MessageBox.Show("Inviting failed", "Msg", MessageBoxButtons.OK); } } else if (NTC.GP_SHOT == gpp) { } else if (NTC.GP_PUTT == gpp) { } else if (NTC.GP_MOVESTOP == gpp) { } else if (NTC.GP_END == gpp) { } else if (NTC.GP_RESULT == gpp) { } } else if (NTC.SC_BROADCAST_READY == opp) { TuserInfo usr = null; uint id = 0; byte ready = 0; idx_bgn = NTC.PCK_HEAD; Packet.ValueFromBuf(ref id, rcv, idx_bgn + 0); Packet.ValueFromBuf(ref ready, rcv, idx_bgn + 4); usr = TcpApp.FindUser(id); usr.ready = ready; PGLog.LOGI("OnRecv:NTC.SC_BROADCAST_READY::" + usr.name + ", " + ready); if (NTC.RST_READY_TRUE == TcpApp.FindUser(app_user_id).ready&& NTC.RST_READY_TRUE == TcpApp.FindUser(app_advr_id).ready) { TcpApp.SendGo(); Program.ChageForm(APC.PHASE_PLAY); } } else if (NTC.SC_BROADCAST_START == opp) { Program.ChageForm(APC.PHASE_PLAY); } } else { PGLog.LOGI("OnRecv: Not defined"); } }
public static int OnIoEvent(int ev, int hr, object socket, int rcn, object data) { if (NTC.EV_CLOSE == ev) { PGLog.LOGI("OnIoEvent: gracefully closed"); golf_net.Program.ChageForm(golf_net.APC.PHASE_BEGIN); } else if (NTC.EV_ACCEPT == ev) { PGLog.LOGI("OnIoEvent: Accept"); } else if (NTC.EV_CONNECT == ev) { PGLog.LOGI("OnIoEvent: Connect"); if (NTC.OK != hr) { PGLog.LOGW("OnIoEvent: Connection Failed"); } } else if (NTC.EV_SEND == ev) { PGLog.LOGI("OnIoEvent: Send::type::" + rcn); } else if (NTC.EV_RECV == ev) { PGLog.LOGI("OnIoEvent: Receive"); byte[] rcv = null; ushort len = 0; ushort opp = 0; int idx_bgn = NTC.PCK_HEAD; int i = 0; if (0 > hr) { PGLog.LOGI("OnIoEvent: disconnected"); TcpCln pCln = (TcpCln)data; golf_net.Program.ChageForm(golf_net.APC.PHASE_BEGIN); return(NTC.OK); } rcv = (byte[])data; len = Packet.LenFromBuf(rcv); opp = Packet.OppFromBuf(rcv); if (NTC.SC_ANS_LOGIN == opp) { byte user_count = 0; app_user_lst.Clear(); app_pmap_lst.Clear(); // setup the user id, and character name Packet.ValFromBuf(ref app_user_id, rcv, idx_bgn + 0); Packet.ValFromBuf(ref app_char_name, rcv, idx_bgn + 4, 40); PGLog.LOGI("OnIoEvent:user id/name::" + app_user_id + ", " + app_char_name); Packet.ValFromBuf(ref user_count, rcv, idx_bgn + 48); idx_bgn = NTC.PCK_HEAD + 49; for (i = 0; i < user_count; ++i) { uint id = 0; string name = null; byte owner = 0; byte ready = 0; Packet.ValFromBuf(ref id, rcv, idx_bgn + 46 * i + 0); Packet.ValFromBuf(ref name, rcv, idx_bgn + 46 * i + 4, 40); Packet.ValFromBuf(ref owner, rcv, idx_bgn + 46 * i + 44); Packet.ValFromBuf(ref ready, rcv, idx_bgn + 46 * i + 45); TuserInfo usr = new TuserInfo(id, name, owner, ready); app_user_lst.Add(usr); PGLog.LOGI("OnIoEvent:NTC.SC_ANS_LOGIN:: id/name::" + id + ", " + name); } for (i = 0; i < 3; ++i) { uint id = (uint)i; string name = "map " + i; TplayMap map = new TplayMap(id, name); app_pmap_lst.Add(map); } // change the phase of the application golf_net.Program.ChageForm(golf_net.APC.PHASE_LOBBY); } else if (NTC.SC_BROADCAST_USERLIST == opp) { byte user_count = 0; idx_bgn = NTC.PCK_HEAD; app_user_lst.Clear(); Packet.ValFromBuf(ref user_count, rcv, idx_bgn + 0); idx_bgn = NTC.PCK_HEAD + 1; for (i = 0; i < user_count; ++i) { uint id = 0; string name = null; byte owner = 0; byte ready = 0; Packet.ValFromBuf(ref id, rcv, idx_bgn + 46 * i + 0); Packet.ValFromBuf(ref name, rcv, idx_bgn + 46 * i + 4, 40); Packet.ValFromBuf(ref owner, rcv, idx_bgn + 46 * i + 44); Packet.ValFromBuf(ref ready, rcv, idx_bgn + 46 * i + 45); TuserInfo usr = new TuserInfo(id, name, owner, ready); app_user_lst.Add(usr); PGLog.LOGI("OnIoEvent:NTC.SC_ANS_LOGIN:: id/name::" + id + ", " + name); } golf_net.Program.ChangeLobbyUserList(0); } else if (NTC.SC_BROADCAST_LOGOUT == opp) { uint id = 0; string name = null; idx_bgn = NTC.PCK_HEAD; Packet.ValFromBuf(ref id, rcv, idx_bgn + 0); name = TcpApp.FindUser(id).name; for (i = 0; i < app_user_lst.Count; ++i) { if (app_user_lst[i].id == id) { app_user_lst.RemoveAt(i); break; } } golf_net.Program.ChangeLobbyUserList(0); PGLog.LOGI("OnIoEvent:NTC.SC_BROADCAST_LOGOUT::" + name); } else if (NTC.CS_REQ_BROADCAST == opp) { // // GAME PLAY PACKET: gpp + send id + {dest id} + data // idx_bgn = NTC.PCK_HEAD; ushort gpp = 0; uint sendId = 0; uint destId = 0; Packet.ValFromBuf(ref gpp, rcv, idx_bgn + 0); // 초대 받음 if (NTC.GP_RQ_INVITE == gpp) { uint idx_map = 0; Packet.ValFromBuf(ref sendId, rcv, idx_bgn + 2); Packet.ValFromBuf(ref destId, rcv, idx_bgn + 2 + 4); Packet.ValFromBuf(ref idx_map, rcv, idx_bgn + 2 + 4 + 4); if (TcpApp.app_user_id == destId) { uint[] arr = new uint[4]; arr[0] = sendId; arr[1] = destId; arr[2] = idx_map; //MessageBox.Show("From " + name + " 한판 뜰래? ", "Inviting", MessageBoxButtons.YesNo); string name = TcpApp.FindUser(sendId).name; string log = "OnIoEvent:NTC.GP_INVITE:: sender:" + name + ", dest id::" + destId + ", map id::" + idx_map; PGLog.LOGI(log); golf_net.Program.ShowMsgBox(new golf_net.FormMsgBox("From " + name + " 한판 뜰래? ", "Inviting", (int)MessageBoxButtons.YesNo, arr, invited_rep)); } } // 초대 응답 else if (NTC.GP_RS_INVITE == gpp) { byte rq = 0; Packet.ValFromBuf(ref sendId, rcv, idx_bgn + 2); Packet.ValFromBuf(ref destId, rcv, idx_bgn + 2 + 4); Packet.ValFromBuf(ref rq, rcv, idx_bgn + 2 + 4 + 4); if (TcpApp.app_user_id == destId) { string name = TcpApp.FindUser(sendId).name; string log = "OnIoEvent:NTC.GP_RS_INVITE::" + name + "::" + rq; PGLog.LOGI(log); // Send Ready if (rq == NTC.RST_OK) { app_oppo_id = sendId; TcpApp.FindUser(app_oppo_id).ready = NTC.RST_READY_TRUE; golf_net.Program.ShowMsgBox(new golf_net.FormMsgBox("Inviting success", "Msg", (int)MessageBoxButtons.OK, null, invited_rqs)); return(NTC.OK); } golf_net.Program.ShowMsgBox(new golf_net.FormMsgBox("Inviting failed", "Msg", (int)MessageBoxButtons.OK, null, null)); } } else if (NTC.GP_PLAY_SHOT == gpp) { idx_bgn = NTC.PCK_HEAD + 2; Packet.ValFromBuf(ref sendId, rcv, idx_bgn + 0 * 4); Packet.ValFromBuf(ref destId, rcv, idx_bgn + 1 * 4); // dest id is me... if (TcpApp.app_oppo_id == sendId && TcpApp.app_user_id == destId) { TplayInfo oppo_p = TcpApp.UserOppo().play; string name = TcpApp.FindUser(sendId).name; float shot_x = 0.0F, shot_y = 0.0F, shot_z = 0.0F; float shot_d = 0.0F; float shot_c_x = 0.0F, shot_c_y = 0.0F; uint shot_club = 0; float shot_pow = 0.0F, shot_best = 0.0F; byte shot_stroke = 0; Packet.ValFromBuf(ref shot_x, rcv, idx_bgn + 2 * 4); Packet.ValFromBuf(ref shot_y, rcv, idx_bgn + 3 * 4); Packet.ValFromBuf(ref shot_z, rcv, idx_bgn + 4 * 4); Packet.ValFromBuf(ref shot_d, rcv, idx_bgn + 5 * 4); Packet.ValFromBuf(ref shot_c_x, rcv, idx_bgn + 6 * 4); Packet.ValFromBuf(ref shot_c_y, rcv, idx_bgn + 7 * 4); Packet.ValFromBuf(ref shot_club, rcv, idx_bgn + 8 * 4); Packet.ValFromBuf(ref shot_pow, rcv, idx_bgn + 9 * 4); Packet.ValFromBuf(ref shot_best, rcv, idx_bgn + 10 * 4); Packet.ValFromBuf(ref shot_stroke, rcv, idx_bgn + 11 * 4); oppo_p.x = shot_x; oppo_p.y = shot_y; oppo_p.z = shot_z; oppo_p.d = shot_d; oppo_p.c_x = shot_c_x; oppo_p.c_y = shot_c_y; oppo_p.club = shot_club; oppo_p.pow = shot_pow; oppo_p.best = shot_best; oppo_p.best = shot_stroke; golf_net.Program.ChangePlayPlayerInfo(0); PGLog.LOGI("OnIoEvent:NTC.NTC.GP_PLAY_SHOT::" + name); } } else if (NTC.GP_PLAY_PUTT == gpp) { idx_bgn = NTC.PCK_HEAD + 2; Packet.ValFromBuf(ref sendId, rcv, idx_bgn + 0 * 4); Packet.ValFromBuf(ref destId, rcv, idx_bgn + 1 * 4); // dest id is me... if (TcpApp.app_oppo_id == sendId && TcpApp.app_user_id == destId) { TplayInfo oppo_p = TcpApp.UserOppo().play; string name = TcpApp.FindUser(sendId).name; float putt_x = 0.0F, putt_y = 0.0F, putt_z = 0.0F; float putt_d = 0.0F; float putt_c_y = 0.0F; uint putt_club = 0; float putt_pow = 0.0F; Packet.ValFromBuf(ref putt_x, rcv, idx_bgn + 2 * 4); Packet.ValFromBuf(ref putt_y, rcv, idx_bgn + 3 * 4); Packet.ValFromBuf(ref putt_z, rcv, idx_bgn + 4 * 4); Packet.ValFromBuf(ref putt_d, rcv, idx_bgn + 5 * 4); Packet.ValFromBuf(ref putt_c_y, rcv, idx_bgn + 6 * 4); Packet.ValFromBuf(ref putt_club, rcv, idx_bgn + 7 * 4); Packet.ValFromBuf(ref putt_pow, rcv, idx_bgn + 8 * 4); oppo_p.x = putt_x; oppo_p.y = putt_y; oppo_p.z = putt_z; oppo_p.d = putt_d; oppo_p.c_y = putt_c_y; oppo_p.club = putt_club; oppo_p.pow = putt_pow; golf_net.Program.ChangePlayPlayerInfo(0); PGLog.LOGI("OnIoEvent:NTC.NTC.GP_PLAY_PUTT::" + name); } } else if (NTC.GP_PLAY_BPOS == gpp) { idx_bgn = NTC.PCK_HEAD + 2; Packet.ValFromBuf(ref sendId, rcv, idx_bgn + 0 * 4); Packet.ValFromBuf(ref destId, rcv, idx_bgn + 1 * 4); // dest id is me... if (TcpApp.app_oppo_id == sendId && TcpApp.app_user_id == destId) { TplayInfo oppo_p = TcpApp.UserOppo().play; string name = TcpApp.FindUser(sendId).name; float bpos_x = 0.0F, bpos_y = 0.0F, bpos_z = 0.0F; Packet.ValFromBuf(ref bpos_x, rcv, idx_bgn + 2 * 4); Packet.ValFromBuf(ref bpos_y, rcv, idx_bgn + 3 * 4); Packet.ValFromBuf(ref bpos_z, rcv, idx_bgn + 4 * 4); oppo_p.x = bpos_x; oppo_p.y = bpos_y; oppo_p.z = bpos_z; golf_net.Program.ChangePlayPlayerInfo(0); PGLog.LOGI("OnIoEvent:NTC.NTC.GP_PLAY_BPOS::" + name); } } else if (NTC.GP_PLAY_END == gpp) { idx_bgn = NTC.PCK_HEAD + 2; Packet.ValFromBuf(ref sendId, rcv, idx_bgn + 0 * 4); Packet.ValFromBuf(ref destId, rcv, idx_bgn + 1 * 4); // dest id is me... if (TcpApp.app_oppo_id == sendId && TcpApp.app_user_id == destId) { TplayInfo oppo_p = TcpApp.UserOppo().play; string name = TcpApp.FindUser(sendId).name; float end_x = 0.0F, end_y = 0.0F, end_z = 0.0F; byte end_stroke = 0; uint end_bonus = 0; Packet.ValFromBuf(ref end_x, rcv, idx_bgn + 2 * 4); Packet.ValFromBuf(ref end_y, rcv, idx_bgn + 3 * 4); Packet.ValFromBuf(ref end_z, rcv, idx_bgn + 4 * 4); Packet.ValFromBuf(ref end_stroke, rcv, idx_bgn + 5 * 4); Packet.ValFromBuf(ref end_bonus, rcv, idx_bgn + 6 * 4); oppo_p.x = end_x; oppo_p.y = end_y; oppo_p.z = end_z; oppo_p.stroke = end_stroke; oppo_p.bonus = end_bonus; PGLog.LOGI("OnIoEvent:NTC.NTC.GP_PLAY_END::" + name); } golf_net.Program.ChangePlayPlayerInfo(0); golf_net.Program.ChangeResultPlayerInfo(0); } } else if (NTC.SC_BROADCAST_READY == opp) { TuserInfo usr = null; uint id = 0; byte ready = 0; idx_bgn = NTC.PCK_HEAD; Packet.ValFromBuf(ref id, rcv, idx_bgn + 0); Packet.ValFromBuf(ref ready, rcv, idx_bgn + 4); usr = TcpApp.FindUser(id); usr.ready = ready; PGLog.LOGI("OnIoEvent:NTC.SC_BROADCAST_READY::" + usr.name + ", " + ready); TuserInfo usrThis = TcpApp.FindUser(app_user_id); TuserInfo usrOther = TcpApp.FindUser(app_oppo_id); if (NTC.RST_READY_TRUE == usrThis.ready && NTC.RST_READY_TRUE == usrOther.ready) { TcpApp.SendGo(); golf_net.Program.ChageForm(golf_net.APC.PHASE_PLAY); golf_net.Program.ChangePlayPlayerInfo(0); } } else if (NTC.SC_BROADCAST_START == opp) { golf_net.Program.ChageForm(golf_net.APC.PHASE_PLAY); } } else { PGLog.LOGI("OnIoEvent: Not defined"); } return(NTC.OK); }