Criando Clan com 2 Jogadores
Olá amiguinhos, hoje estarei postando um tutorial de como deixar seu gunz, pra criar clan com 2 jogadores, (Em todos os gunz precisam de 4 jogadores, e etc, mas seguindo esse tutorial, consegue fazer com 2 somente.)
Tutorial:
Vá na CSCommon da sua source, e abra o arquivo MAsyncDBJob.h :
Procure por:
Procure por:
class MAsyncDBJob_CreateClan : public MAsyncJob {
Susbtitua toda a class por:
////////////////////////////////////////////////////////////////////////////////////////////////////
class MAsyncDBJob_CreateClan : public MAsyncJob {
protected:
MUID m_uidMaster;
MUID m_uidMember1;
// MUID m_uidMember2;
// MUID m_uidMember3;
// MUID m_uidMember4;
protected: // Input Argument
char m_szClanName[256];
int m_nMasterCID;
int m_nMember1CID;
// int m_nMember2CID;
// int m_nMember3CID;
// int m_nMember4CID;
protected: // Output Result
bool m_bDBResult;
int m_nNewCLID;
public:
MAsyncDBJob_CreateClan(const MUID& uidOwne) : MAsyncJob(MASYNCJOB_CREATECLAN, uidOwne) ,
m_bDBResult(false),
m_nNewCLID(0)
{
}
virtual ~MAsyncDBJob_CreateClan() {}
bool Input(const TCHAR* szClanName,
const int nMasterCID,
const int nMember1CID,
// const int nMember2CID,
// const int nMember3CID,
// const int nMember4CID,
const MUID& uidMaster,
const MUID& uidMember1);
// const MUID& uidMember2,
// const MUID& uidMember3,
// const MUID& uidMember4);
virtual void Run(void* pContext);
bool GetDBResult() { return m_bDBResult; }
int GetNewCLID() { return m_nNewCLID; }
const MUID& GetMasterUID() { return m_uidMaster; }
const MUID& GetMember1UID() { return m_uidMember1; }
// const MUID& GetMember2UID() { return m_uidMember2; }
// const MUID& GetMember3UID() { return m_uidMember3; }
// const MUID& GetMember4UID() { return m_uidMember4; }
const char* GetClanName() { return m_szClanName; }
};
////////////////////////////
Agora, na MMatchGlobal.h;
Procure por:
#define CLAN_SPONSORS_COUNT 4 // Ŭ·£»ý¼º½Ã ÇÊ¿äÇÑ ¹ß±âÀÎ ¼ö
Troque por:
#define CLAN_SPONSORS_COUNT 1 // Ŭ·£»ý¼º½Ã ÇÊ¿äÇÑ ¹ß±âÀÎ ¼ö
Agora, na MMatchDBMgr.h;
Procure por:
bool CreateClan(const TCHAR* szClanName, const int nMasterCID, const int nMember1CID, const int nMember2CID,
const int nMember3CID, const int nMember4CID, bool* boutRet, int* noutNewCLID);
Substitua por:
bool CreateClan(const TCHAR* szClanName, const int nMasterCID, const int nMember1CID, bool* boutRet, int* noutNewCLID);
Agora em MAsyncDBJob.cpp;
Procure por:
void MAsyncDBJob_CreateClan::Run(void* pContext)
Substitua toda a class por:
/////////////////////////////////////////////////////////////////////////////////////////////////
void MAsyncDBJob_CreateClan::Run(void* pContext)
{
MMatchDBMgr* pDBMgr = (MMatchDBMgr*)pContext;
if (!pDBMgr->CreateClan(m_szClanName,
m_nMasterCID,
m_nMember1CID,
// m_nMember2CID,
// m_nMember3CID,
// m_nMember4CID,
&m_bDBResult,
&m_nNewCLID))
{
SetResult(MASYNC_RESULT_FAILED);
return;
}
SetResult(MASYNC_RESULT_SUCCEED);
}
bool MAsyncDBJob_CreateClan::Input(const TCHAR* szClanName,
const int nMasterCID,
const int nMember1CID,
// const int nMember2CID,
// const int nMember3CID,
// const int nMember4CID,
const MUID& uidMaster,
const MUID& uidMember1)
// const MUID& uidMember2,
// const MUID& uidMember3,
// const MUID& uidMember4)
{
strcpy(m_szClanName, szClanName);
m_nMasterCID = nMasterCID;
m_nMember1CID = nMember1CID;
// m_nMember2CID = nMember2CID;
// m_nMember3CID = nMember3CID;
// m_nMember4CID = nMember4CID;
m_uidMaster = uidMaster;
m_uidMember1 = uidMember1;
// m_uidMember2 = uidMember2;
// m_uidMember3 = uidMember3;
// m_uidMember4 = uidMember4;
return true;
}
//////////////////////////////
Em MMatchDBMgr.cpp;
Procure por:
TCHAR g_szDB_CREATE_CLAN[] = _T("{CALL spCreateClan ('%s', %d, %d, %d, %d, %d)}");
Substitua por:
TCHAR g_szDB_CREATE_CLAN[] = _T("{CALL spCreateClan ('%s', %d, %d)}");
No mesmo arquivo, MMatchDBMgr.cpp;
Procure por:
bool MMatchDBMgr::CreateClan(const TCHAR* szClanName, const int nMasterCID, const int nMember1CID, const int nMember2CID,
const int nMember3CID, const int nMember4CID, bool* boutRet, int* noutNewCLID)
Substitua todo caso por:
bool MMatchDBMgr::CreateClan(const TCHAR* szClanName, const int nMasterCID, const int nMember1CID, bool* boutRet, int* noutNewCLID)
{
_STATUS_DB_START;
if (!CheckOpen()) return false;
CString strSQL;
strSQL.Format(g_szDB_CREATE_CLAN, szClanName, nMasterCID, nMember1CID);
CODBCRecordset rs(&m_DB);
bool bException = false;
try
{
rs.Open(strSQL, CRecordset::forwardOnly, CRecordset::readOnly);
}
catch(CDBException* e)
{
bException = true;
ExceptionHandler(strSQL, e);
return false;
*boutRet = false;
return false;
}
if ((rs.IsOpen() == FALSE) || (rs.GetRecordCount() {
*boutRet = false;
return false;
}
*boutRet = rs.Field("Ret").AsBool();
*noutNewCLID = rs.Field("NewCLID").AsInt();
_STATUS_DB_END(35);
return true;
}
Agora em MMatchServer_Async.cpp;
Procure por:
_ASSERT(CLAN_SPONSORS_COUNT == 4);
pSponsorObjects[0] = GetObject(pJob->GetMember1UID());
pSponsorObjects[1] = GetObject(pJob->GetMember2UID());
pSponsorObjects[2] = GetObject(pJob->GetMember3UID());
pSponsorObjects[3] = GetObject(pJob->GetMember4UID());
Substitua por:
_ASSERT(CLAN_SPONSORS_COUNT == 1);
pSponsorObjects[0] = GetObject(pJob->GetMember1UID());
//pSponsorObjects[1] = GetObject(pJob->GetMember2UID());
//pSponsorObjects[2] = GetObject(pJob->GetMember3UID());
//pSponsorObjects[3] = GetObject(pJob->GetMember4UID());
Em MMatchServer_Clan.cpp ;
Procure por:
if (CLAN_SPONSORS_COUNT == 4)
Substitua toda a “if” por:
if (CLAN_SPONSORS_COUNT == 1)
{
MAsyncDBJob_CreateClan* pNewJob = new MAsyncDBJob_CreateClan(uidPlayer);
pNewJob->Input(szClanName,
nMasterCID,
nMemberCID[0],
// nMemberCID[1],
// nMemberCID[2],
// nMemberCID[3],
pMasterObject->GetUID(),
pSponsorObjects[0]->GetUID());
// pSponsorObjects[1]->GetUID());
// pSponsorObjects[2]->GetUID(),
// pSponsorObjects[3]->GetUID());
// PostAsyncJob(pNewJob);
pMasterObject->m_DBJobQ.DBJobQ.push_back( pNewJob );
}
Em MSharedCommandTable.cpp;
Procure por:
C(MC_MATCH_CLAN_REQUEST_AGREED_CREATE_CLAN, "Match.Clan.RequestAgreedCreateClan", "Request Agreed Create Clan", MCDT_MACHINE2MACHINE)
Substitua tudo por:
C(MC_MATCH_CLAN_REQUEST_AGREED_CREATE_CLAN, "Match.Clan.RequestAgreedCreateClan", "Request Agreed Create Clan", MCDT_MACHINE2MACHINE)
P(MPT_UID, "uidChar") // ¿äûÇÑ Ä³¸¯ÅÍ UID
P(MPT_STR, "ClanName") // »ý¼ºÇÒ Å¬·£ À̸§
P(MPT_STR, "Member1CharName") // ¹ß±âÀΠij¸¯ÅÍ À̸§
// P(MPT_STR, "Member2CharName") // ¹ß±âÀΠij¸¯ÅÍ À̸§
// P(MPT_STR, "Member3CharName") // ¹ß±âÀΠij¸¯ÅÍ À̸§
// P(MPT_STR, "Member4CharName") // ¹ß±âÀΠij¸¯ÅÍ À̸§
Agora, na sua source, vá na pasta Gunz (Se não me engano, é Stable/Gunz), procure por
ZPost.h
Procure por:
inline void ZPostRequestCreateClan(const MUID& uidChar, const int nRequestID, char* szClanName,
Substitua tudo por:
inline void ZPostRequestCreateClan(const MUID& uidChar, const int nRequestID, char* szClanName,
char** ppMemberCharNames, int nMemberCharNamesCount)
{
if (nMemberCharNamesCount != CLAN_SPONSORS_COUNT) return;
ZPOSTCMD4(MC_MATCH_CLAN_REQUEST_CREATE_CLAN, MCmdParamUID(uidChar), MCmdParamInt(nRequestID), MCmdParamStr(szClanName),
MCmdParamStr(ppMemberCharNames[0]));
}
Agora, salve tudo, abra seu SQL Server, e faça o seguinte:
Dê um duplo clique eu sua GunzDB, duplo clique em Programmability, e mais um duplo clique emStoredProcedures, e procure por spCreateClan :
Substitua tudo por:
USE [GunzDB]
GO
/****** Object: StoredProcedure [dbo].[spCreateClan] Script Date: 03/01/2013 10:15:41 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- Ŭ·£ »ý¼ºÇϱâ
ALTER PROC [dbo].[spCreateClan]
@ClanName varchar(24),
@MasterCID int,
@Member1CID int
AS
DECLARE @NewCLID int
-- Ŭ·£À̸§ÀÌ Áߺ¹ÀÎÁö °Ë»çÇؾßÇÑ´Ù.
SELECT @NewCLID=CLID FROM Clan(NOLOCK) WHERE Name=@ClanName
IF @NewCLID IS NOT NULL
BEGIN
SELECT 0 AS Ret, 0 AS NewCLID
RETURN
END
DECLARE @CNT int
-- Ŭ·£¿øÀÌ ¸ðµÎ °¡ÀÔ °¡´ÉÇÑÁö °Ë»çÇؾßÇÑ´Ù.
SELECT @CNT = COUNT(*) FROM ClanMember cm(NOLOCK), Character c(NOLOCK) WHERE ((cm.CID=@MasterCID) OR (cm.CID=@Member1CID) ) AND cm.CID=c.CID AND c.DeleteFlag=0
IF @CNT != 0
BEGIN
SELECT 0 AS Ret, 0 AS NewCLID
RETURN
END
BEGIN TRAN
-- Ŭ·£ »ý¼º
INSERT INTO Clan (Name, MasterCID, RegDate) VALUES (@ClanName, @MasterCID, GETDATE())
IF 0 <> @@ERROR BEGIN
ROLLBACK TRAN
SELECT 0 AS Ret, 0 AS NewCLID
RETURN
END
SELECT @NewCLID = @@IDENTITY
IF (@NewCLID IS not NULL)
BEGIN
DECLARE @Err1 int
DECLARE @Err2 int
DECLARE @Err3 int
DECLARE @Err4 int
DECLARE @Err5 int
-- Ŭ·£¿ø °¡ÀÔ
INSERT INTO ClanMember (CLID, CID, Grade, RegDate) VALUES (@NewCLID, @MasterCID, 1, GETDATE())
SET @Err1 = @@ERROR
INSERT INTO ClanMember (CLID, CID, Grade, RegDate) VALUES (@NewCLID, @Member1CID, 9, GETDATE())
SET @Err2 = @@ERROR
IF (0 <> @Err1) OR (0 <> @Err2) BEGIN
ROLLBACK TRAN
SELECT 0 AS Ret, 0 AS NewCLID
RETURN
END
END
COMMIT TRAN
-- ¸¶½ºÅÍ ¹Ù¿îƼ »èÁ¦
--UPDATE Character SET BP=BP-1000 WHERE CID=@MasterCID
SELECT 1 AS Ret, @NewCLID AS NewCLID