嘿COM,
- s8 i3 o. N* l6 tNEN有点无聊和我开始思考,我写的关于如何得到从GM -喊名字一点时间NEN啧。! s# v [6 n3 G0 m/ G2 o1 m6 D
后,整个看起来像这样:
) ?6 G, h6 Z% X* B f: `
' w6 a" { m% u) {8 {9 G: k
& `- p; Q. ^' c9 s T& e+ I可我第一次补习,所以如果有批评,请说,从而提高自我。
/ ^3 e9 o$ n2 D) P+ ~我不知道我的代码是最优的,肯定有一个更好的解决办法,我还是C ++初学者。
5 o3 @! H, n# ~" ?' G0 T. O5 i# X/ U: }( v, `
所以,当你第一次打开了FuncTextCmd.cpp和搜索# n. P `! d0 I8 b
) V% X K6 |. {) e5 k' B" K
代码: BOOL TextCmd_System( CScanner& scanner ) * d& _6 Q* \; |( i, C2 o
在那里,您会发现:% r C9 A! a& Q8 K
代码: { #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; }
( C7 R f9 S* D! M现在我们引入一个新的变量,我只需调用szName的
# k {. ^2 v- g a" x那么整个事情看起来像这样:
% }: n+ ~" m8 S; w代码: { #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; }
2 v; y2 P2 f' Z9 x) |$ i+ y变量我们也等于“[”拯救我们以后的工作XD
7 b3 i; W6 [1 D, ^3 s, j( {
4 ~0 V% {5 U, L6 d4 k) c然后,我们明确了scanner.GetLastFull测试()源;在g_DPCoreClient.SendSystem(szString)。
5 M: g v7 ]8 G+ a! ?
! i7 g! p5 Z' ~( }, F# R( y; h6 y整个事情是这样的:7 x/ ~6 i8 u- J, W
代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CHAR szName[512] = "["; CUser* pUser =(CUser*)scanner.dwValue; #endif // __WORLDSERVER return TRUE; } , q4 ?; b/ Q3 D
并提出了下列:" Y0 P3 S- ^$ _1 k5 ]4 w6 i) a) C
代码: { #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 y1 X) O0 V% [$ Q7 L r9 d现在,通用汽车应该喊这样的:
0 b5 o9 \: M3 R( K* S代码: [GM Information][NAME] TEXT
2 X2 _. i& I: i9 o( E& r4 |现在,如果你仍然希望出现这种情况,例如有管理员将需要插入她的下列内容:3 D1 m) l2 H$ J; u2 [* l: d
代码: { #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; } 9 c, A- M3 z0 y
如果你想不仅为管理这一点,你必须始终
3 T( O, T5 j' R: B" v3 E/ f1 R代码: else if(pUser->m_dwAuthorization == AUTHORIZATION) strcat( szName, "Admin][" );
, f: |6 V# K5 a7 C6 ?补充。8 ?: i* z: ~& K6 A" E; m$ u
3 l; x+ x- [& l2 m7 J$ }1 O' j( K
; y& a) A- U% G6 M1 B0 Z; J7 J0 T3 P下面是与使用/ SYS解决不同的授权清单:' X' e$ _. n' C9 ?9 G I
代码: AUTH_GAMEMASTER1 //Gamemaster lvl 1 AUTH_GAMEMASTER2 //Gamemaster lvl 2 AUTH_GAMEMASTER3 //Gamemaster lvl 3 AUTH_ADMINISTRATOR //Administrator
w9 f7 ]0 z- W) B; D' ^9 } G* B4 K希望你喜欢指导,批评是欢迎的。! z3 a9 I3 W7 H5 c; Y* _
4 U- x/ @8 ^" Y- X
制作所Pumbaaa 0 N* u. @$ _9 e) ~( }' L* r- _
|