嘿COM,8 v$ U) J x. R# K- n" u
NEN有点无聊和我开始思考,我写的关于如何得到从GM -喊名字一点时间NEN啧。
1 U# |. P0 W3 o后,整个看起来像这样:
5 \; e$ }2 }- @/ }
/ i3 s* E! |4 N# f3 B/ n2 b9 @4 a( w9 T* _( x1 W
可我第一次补习,所以如果有批评,请说,从而提高自我。& I0 d; }' ?- U) Y0 }
我不知道我的代码是最优的,肯定有一个更好的解决办法,我还是C ++初学者。' A; O7 ^; j, W/ Q
@3 Z/ e2 i2 a所以,当你第一次打开了FuncTextCmd.cpp和搜索% s. }9 z" `, W2 a, ]: T
) `- n8 k/ v# O- ?. I4 ]
代码: BOOL TextCmd_System( CScanner& scanner ) 1 X7 V/ j# Y1 L3 D- z; i
在那里,您会发现:$ W: i+ z+ N) R- c5 |) Y! J
代码: { #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 R+ i6 z- x* X+ I) ~$ u/ Z* v/ m& C现在我们引入一个新的变量,我只需调用szName的* |! g4 K( _- h0 r' \ f: I
那么整个事情看起来像这样:
; i7 T+ J; v( J2 r$ J! {3 }+ G! n代码: { #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; } % }$ ?& t5 p6 z$ w$ m( s
变量我们也等于“[”拯救我们以后的工作XD
0 v4 k2 W/ p. q- {# O( F" D. O1 l7 L& A7 J% ^# X
然后,我们明确了scanner.GetLastFull测试()源;在g_DPCoreClient.SendSystem(szString)。0 }( {0 A, o& Z U) \% _# C
8 R/ e# `! x$ t9 y) H, d整个事情是这样的:* s3 Q b1 I, }+ ^
代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CHAR szName[512] = "["; CUser* pUser =(CUser*)scanner.dwValue; #endif // __WORLDSERVER return TRUE; }
3 P r }, _% [1 _+ i0 n" p并提出了下列:
4 @7 }. N. ]9 l+ D代码: { #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; }
9 B3 e$ @# ?5 T2 b- @; C5 ^2 q5 u现在,通用汽车应该喊这样的:! O$ q5 p# U1 h8 d
代码: [GM Information][NAME] TEXT 3 S3 A1 F' C; N2 @
现在,如果你仍然希望出现这种情况,例如有管理员将需要插入她的下列内容:
- a# j* Q2 t, T' a0 H( N) c4 m0 s代码: { #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; }
" {8 O' ^: D, }& E如果你想不仅为管理这一点,你必须始终
$ d9 `# |" L( w( }& q1 b代码: else if(pUser->m_dwAuthorization == AUTHORIZATION) strcat( szName, "Admin][" ); $ \) ~' Z5 k5 C
补充。( S9 D: g& {3 s; H8 U
- s! w8 r8 g7 d3 S8 w% P: K- [& ~: G7 U+ i7 m) }1 S; s
下面是与使用/ SYS解决不同的授权清单:" p9 @- \' A$ y- j/ z1 G/ j
代码: AUTH_GAMEMASTER1 //Gamemaster lvl 1 AUTH_GAMEMASTER2 //Gamemaster lvl 2 AUTH_GAMEMASTER3 //Gamemaster lvl 3 AUTH_ADMINISTRATOR //Administrator 3 o4 ^% N* `+ T$ z+ c" o) C% e$ Y
希望你喜欢指导,批评是欢迎的。! u$ d! ]0 q& z( j% J5 u! n4 L
; w/ u$ k+ Q$ C5 L9 r制作所Pumbaaa
) i$ M, r; \' U1 R |