|
嘿COM,. b" _9 A9 n8 U, C" @: U/ U& \
NEN有点无聊和我开始思考,我写的关于如何得到从GM -喊名字一点时间NEN啧。
* r% W2 H7 K2 G6 @. w; |7 W后,整个看起来像这样:
& J4 _2 {' r# u9 H 2 d8 M9 K- p8 W
* c( B" c! X/ G1 K, v+ K可我第一次补习,所以如果有批评,请说,从而提高自我。
P, v& N5 V8 p# F3 y我不知道我的代码是最优的,肯定有一个更好的解决办法,我还是C ++初学者。 [. R% M% S1 F4 ~6 i2 x2 Z, B
1 r3 n. y- b$ N# L: Q, g( h; M, R所以,当你第一次打开了FuncTextCmd.cpp和搜索
+ b! Z) Q9 c; u3 n
- v+ y! C8 J$ ~& ` _3 Z代码: BOOL TextCmd_System( CScanner& scanner ) & E+ C3 e' g" r
在那里,您会发现:
& X+ P8 u. b6 H代码: { #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; }
& w5 k6 { _ q; l* u现在我们引入一个新的变量,我只需调用szName的
0 A* W- k, e" w5 ?7 L5 O" T+ v9 {那么整个事情看起来像这样:, F+ o; g8 s4 t- J+ 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; } & ~# a3 G" c! f# L) z
变量我们也等于“[”拯救我们以后的工作XD- O1 M: E3 r: ^( |
3 g' ~$ ~# W& \* S
然后,我们明确了scanner.GetLastFull测试()源;在g_DPCoreClient.SendSystem(szString)。0 u# j: Y3 o5 F" M9 H8 @
" ?" m: y0 o. w, g6 N整个事情是这样的:
0 V" I9 R7 H2 h; U# j+ k1 |代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CHAR szName[512] = "["; CUser* pUser =(CUser*)scanner.dwValue; #endif // __WORLDSERVER return TRUE; }
5 U0 x& y% N. J: M3 Q. o9 t9 I并提出了下列:
' I: g2 n; Y) ?% n# d4 F7 s代码: { #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; } 8 N) w/ T% ?# l" @
现在,通用汽车应该喊这样的:
, E* _& \) p$ o: x6 N: n代码: [GM Information][NAME] TEXT 0 d$ n4 g' W0 |9 O& d# Q: J
现在,如果你仍然希望出现这种情况,例如有管理员将需要插入她的下列内容:
8 {7 r! { s' L' R! K& `代码: { #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; } . B0 `+ Q9 D3 O
如果你想不仅为管理这一点,你必须始终# T7 ]' ~" u; E- w3 ?8 u. K
代码: else if(pUser->m_dwAuthorization == AUTHORIZATION) strcat( szName, "Admin][" );
2 ], C4 O: I! J/ j2 n补充。+ [4 o$ `3 ~' Y* y, g# }$ ?! D# z2 u
6 T1 r% Q% ~9 |$ `; t& W% T
; e2 t- A; Z% j7 O下面是与使用/ SYS解决不同的授权清单:
4 U% d! k7 R' W% s6 h代码: AUTH_GAMEMASTER1 //Gamemaster lvl 1 AUTH_GAMEMASTER2 //Gamemaster lvl 2 AUTH_GAMEMASTER3 //Gamemaster lvl 3 AUTH_ADMINISTRATOR //Administrator ( e$ i6 [" d3 f/ T2 X5 Z! l# V7 m# Y
希望你喜欢指导,批评是欢迎的。
3 o0 j, W& `6 B% V
$ g5 A7 t2 ^, a4 E* w9 f7 J制作所Pumbaaa 9 {. w9 K& P0 R, @
|