|
嘿COM,
0 v# G" }2 X4 g* p% A3 iNEN有点无聊和我开始思考,我写的关于如何得到从GM -喊名字一点时间NEN啧。2 d) k w6 v& G8 d' @
后,整个看起来像这样:
" ~ h1 X! R9 a! a+ ]
2 A. k& Q/ U0 c6 M# e- _8 d" Z' S) E2 d: J4 ~ o+ d
可我第一次补习,所以如果有批评,请说,从而提高自我。* a5 I0 f9 q& F' o4 d
我不知道我的代码是最优的,肯定有一个更好的解决办法,我还是C ++初学者。( w: I5 x" g: J) I
% W& w5 L- g$ ~$ F: @4 W所以,当你第一次打开了FuncTextCmd.cpp和搜索% o1 L( W3 w+ S
2 w7 m9 k/ W# @代码: BOOL TextCmd_System( CScanner& scanner ) 5 ]% K8 o' x5 R
在那里,您会发现:
1 t9 u/ H) u/ f( D" |# R/ @ q代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CUser* pUser =(CUser*)scanner.dwValue; scanner.GetLastFull(); if( strlen( scanner.token ) >= 512 ) return TRUE; strcpy( szString, scanner.token ); StringTrimRight( szString ); g_DPCoreClient.SendSystem( szString ); #endif // __WORLDSERVER return TRUE; } 7 G5 u! L) |' o% ]5 A# g: O) Z0 [
现在我们引入一个新的变量,我只需调用szName的5 |- } {3 a$ ?& A& }% U
那么整个事情看起来像这样:$ f0 t, s6 h7 D, }0 v7 o& Z3 q& }
代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CHARszName[512] = "["; CUser* pUser =(CUser*)scanner.dwValue; scanner.GetLastFull(); if( strlen( scanner.token ) >= 512 ) return TRUE; strcpy( szString, scanner.token ); StringTrimRight( szString ); g_DPCoreClient.SendSystem( szString ); #endif // __WORLDSERVER return TRUE; } 0 S( S+ x5 c" ]0 \; y! h% r; q
变量我们也等于“[”拯救我们以后的工作XD# P" v0 S2 m \) ]% q' `( x2 |
' c+ H- Z9 f9 F然后,我们明确了scanner.GetLastFull测试()源;在g_DPCoreClient.SendSystem(szString)。
) h1 M, m+ o l* D$ i& j4 ]
+ l# k$ w1 v! m整个事情是这样的:( S1 l/ E0 C8 J( ]+ H5 l5 \+ _
代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CHAR szName[512] = "["; CUser* pUser =(CUser*)scanner.dwValue; #endif // __WORLDSERVER return TRUE; } - {1 j7 w/ O; V5 ^
并提出了下列:
- b1 r7 o; E: G代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CHAR szName[512] = "["; CUser* pUser =(CUser*)scanner.dwValue; strcat( szName, pUser->GetName()); strcat( szName, "]: "); scanner.GetLastFull(); if( strlen( scanner.token ) >= 512 ) return TRUE; strcpy( szString, scanner.token ); StringTrimRight( szString ); strcat( szName, szString ); g_DPCoreClient.SendSystem( szName ); #endif // __WORLDSERVER return TRUE; } - p7 {3 p3 _/ R& g# s$ g# K5 k
现在,通用汽车应该喊这样的:
8 |% M0 T$ d! O- z2 f代码: [GM Information][NAME] TEXT
8 N* g& W( x! k2 ~9 `1 P) j现在,如果你仍然希望出现这种情况,例如有管理员将需要插入她的下列内容:
) G0 U& H; {! {0 S' X- p" u代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CHAR szName[512] = "["; CUser* pUser =(CUser*)scanner.dwValue; //FüR ADMIN if(pUser->m_dwAuthorization ==AUTH_ADMINISTRATOR) strcat( szName,"Admin][" ); strcat( szName, "TestGM][" ); strcat( szName, pUser->GetName()); strcat( szName, "]: "); scanner.GetLastFull(); if( strlen( scanner.token ) >= 512 ) return TRUE; strcpy( szString, scanner.token ); StringTrimRight( szString ); strcat( szName, szString ); g_DPCoreClient.SendSystem( szName ); #endif // __WORLDSERVER return TRUE; }
3 y- p5 w L% W如果你想不仅为管理这一点,你必须始终! n* z( o+ K J3 D" x0 j6 h1 A+ r
代码: else if(pUser->m_dwAuthorization == AUTHORIZATION) strcat( szName, "Admin][" ); $ F! [& w, P2 l9 [) ^6 O
补充。4 T2 d8 a$ h1 m0 g8 w' V, c2 U0 V( j
: H% M3 k0 K- P1 L; P' b) v9 m. X- }7 R/ U: u6 N# G/ V. N+ N
下面是与使用/ SYS解决不同的授权清单:1 ?! V1 {7 w, y+ b1 f4 A
代码: AUTH_GAMEMASTER1 //Gamemaster lvl 1 AUTH_GAMEMASTER2 //Gamemaster lvl 2 AUTH_GAMEMASTER3 //Gamemaster lvl 3 AUTH_ADMINISTRATOR //Administrator
: b: d/ u. B: L4 V6 E! K1 G" U4 f希望你喜欢指导,批评是欢迎的。
5 r; F& h8 h9 j# g% {% s! \/ D8 Q1 T8 g* V9 v" Y! [* e
制作所Pumbaaa
: y" ~- f; X4 T4 } |