Ejemplo n.º 1
0
        /// <summary>
        /// TimedAutoMatch的子函数,成功坐下
        /// </summary>
        /// <param name="room"></param>
        /// <param name="userSession"></param>
        private void TimedAutoMatchRoom_Sub_SitDown_Ok(IRoomModel room, AppSession userSession)
        {
            try
            {
               
                string svrAction = ServerAction.joinOK;

                //
                StringBuilder contentXml = new StringBuilder();

                //获取房间的xml输出
                //IRoomModel room = logicGetRoom(roomId);
                string roomXml = room.toXMLString();

                //坐下成功不需要code
                //contentXml.Append("<code>0</code>");
                contentXml.Append(roomXml);

                //回复
                Send(userSession,

                    XmlInstruction.fengBao(svrAction, contentXml.ToString())

                    );

                //log
                Log.WriteStrBySend(svrAction, userSession.RemoteEndPoint.ToString());

                //转发 uER = UserEnterRoom
                string svrAction_uER = ServerAction.uER;

                IUserModel sitDownUser = logicGetUser(userSession.RemoteEndPoint.ToString());

                string chairAndUserXml = room.getChair(sitDownUser).toXMLString();

                netTurnRoom(userSession.RemoteEndPoint.ToString(), room.Id, svrAction_uER, chairAndUserXml);

                Log.WriteStrByTurn(SR.Room_displayName + room.Id.ToString(), "", svrAction_uER);

                
            }
            catch (Exception exd)
            {
                Log.WriteStrByException(CLASS_NAME, "TimedAutoMatch_Sub_SitDown", exd.Message, exd.Source, exd.StackTrace);
            }

        }