|
嘿COM,8 v4 v' x, t" K' j' a) K
NEN有点无聊和我开始思考,我写的关于如何得到从GM -喊名字一点时间NEN啧。* x( F! h! [" r$ d+ L: j
后,整个看起来像这样:, C2 g1 o/ U4 ^0 U
1 _/ {- n1 {' y8 M4 I0 ^9 h
( Z6 n, ^" t/ k" S
可我第一次补习,所以如果有批评,请说,从而提高自我。* t2 V f* |8 e: ?9 h
我不知道我的代码是最优的,肯定有一个更好的解决办法,我还是C ++初学者。2 ^8 A3 `* }' ]3 s, A# |. \" b
! I0 |- t9 ^& s5 W所以,当你第一次打开了FuncTextCmd.cpp和搜索8 ?7 d' m" \: Z- K! C- ~) `
' \ G! d3 n4 r! v2 o& @ F! t" [
代码: BOOL TextCmd_System( CScanner& scanner )
) f3 q1 p( r' z! O3 X7 s在那里,您会发现:7 o* [- |1 m# T; \
代码: { #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; }
% B! s8 b; Z& T5 g% `3 U) V现在我们引入一个新的变量,我只需调用szName的
% N6 C% d% d5 j/ W% }那么整个事情看起来像这样:: ]7 J! T% M9 x8 L
代码: { #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; } 9 A9 r2 W d+ T6 k v6 R V
变量我们也等于“[”拯救我们以后的工作XD2 Q" h/ s( ~9 i4 ^& `0 A' {
6 |, A. w9 k" z8 u
然后,我们明确了scanner.GetLastFull测试()源;在g_DPCoreClient.SendSystem(szString)。 X8 T: {: V# V9 c, r# J7 C
2 f( \% q: E* e' L3 ~整个事情是这样的:6 P/ j% c" N4 a, c
代码: { #ifdef __WORLDSERVER CHAR szString[512] = ""; CHAR szName[512] = "["; CUser* pUser =(CUser*)scanner.dwValue; #endif // __WORLDSERVER return TRUE; }
8 o- K( d0 F% Q并提出了下列:
( P) T. H( W) O0 n a1 x7 Q代码: { #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; } : q+ u+ B& o p$ C0 {
现在,通用汽车应该喊这样的:
& {! e9 r4 n T6 x) Q代码: [GM Information][NAME] TEXT $ ?% R6 R3 J5 W' d
现在,如果你仍然希望出现这种情况,例如有管理员将需要插入她的下列内容:
3 C. Y6 x3 j: @, S2 O" ^& [代码: { #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; }
, T( r: _4 e$ S% n6 ]& c" }% B% H如果你想不仅为管理这一点,你必须始终9 v* {7 P; i# o) E- U
代码: else if(pUser->m_dwAuthorization == AUTHORIZATION) strcat( szName, "Admin][" );
3 W: v/ b$ L1 |, J& t7 [+ J. q补充。0 A% Y1 d% `( q0 U4 Z c
) q4 n1 Y, T/ {# X& i$ \* x9 S3 O! j0 m
下面是与使用/ SYS解决不同的授权清单:# }& }( O* ^" A( N3 B
代码: AUTH_GAMEMASTER1 //Gamemaster lvl 1 AUTH_GAMEMASTER2 //Gamemaster lvl 2 AUTH_GAMEMASTER3 //Gamemaster lvl 3 AUTH_ADMINISTRATOR //Administrator 8 Z k: M8 k8 k5 `% H# l
希望你喜欢指导,批评是欢迎的。# {) L- |# w) @" {! N! P
! V0 d0 Q- D* \ m$ O0 k
制作所Pumbaaa # Q% y8 L2 K7 a( s2 Z4 m T# d
|