本文整理匯總了C++中GML_RECMUTEX_LOCK函數的典型用法代碼示例。如果您正苦於以下問題:C++ GML_RECMUTEX_LOCK函數的具體用法?C++ GML_RECMUTEX_LOCK怎麽用?C++ GML_RECMUTEX_LOCK使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了GML_RECMUTEX_LOCK函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: GML_RECMUTEX_LOCK
void CGroupHandler::RemoveGroup(CGroup* group)
{
GML_RECMUTEX_LOCK(sel); // RemoveGroup
GML_STDMUTEX_LOCK(group); // RemoveGroup
if(group->id<10){
logOutput.Print("Warning trying to remove hotkey group %i",group->id);
return;
}
if(selectedUnits.selectedGroup==group->id)
selectedUnits.ClearSelected();
groups[group->id]=0;
freeGroups.push_back(group->id);
delete group;
}
示例2: GML_RECMUTEX_LOCK
void CGroupHandler::RemoveGroup(CGroup* group)
{
GML_RECMUTEX_LOCK(grpsel); // RemoveGroup
if (group->id < FIRST_SPECIAL_GROUP) {
LOG_L(L_WARNING, "Trying to remove hot-key group %i", group->id);
return;
}
if (selectedUnits.selectedGroup == group->id) {
selectedUnits.ClearSelected();
}
groups[group->id] = NULL;
freeGroups.push_back(group->id);
delete group;
}
示例3: GML_RECMUTEX_LOCK
void CSelectedUnits::ClearSelected()
{
GML_RECMUTEX_LOCK(sel); // ClearSelected
CUnitSet::iterator ui;
for (ui = selectedUnits.begin(); ui != selectedUnits.end(); ++ui) {
(*ui)->isSelected = false;
DeleteDeathDependence(*ui, DEPENDENCE_SELECTED);
}
selectedUnits.clear();
selectionChanged = true;
possibleCommandsChanged = true;
selectedGroup = -1;
}
示例4: GetMyTeamUnit
bool CAICallback::AddUnitToGroup(int unitId, int groupId)
{
bool added = false;
CUnit* unit = GetMyTeamUnit(unitId);
if (unit) {
GML_RECMUTEX_LOCK(group); // AddUnitToGroup
if (CHECK_GROUPID(groupId) && gh->groups[groupId]) {
added = unit->SetGroup(gh->groups[groupId]);
}
}
return added;
}
示例5: GML_RECMUTEX_LOCK
void CGroupHandler::GroupCommand(int num)
{
GML_RECMUTEX_LOCK(sel); // GroupCommand
GML_STDMUTEX_LOCK(group); // GroupCommand
if (keys[SDLK_LCTRL]) {
if (!keys[SDLK_LSHIFT]) {
groups[num]->ClearUnits();
}
const CUnitSet& selUnits = selectedUnits.selectedUnits;
CUnitSet::const_iterator ui;
for(ui = selUnits.begin(); ui != selUnits.end(); ++ui) {
(*ui)->SetGroup(groups[num]);
}
}
else if (keys[SDLK_LSHIFT]) {
// do not select the group, just add its members to the current selection
CUnitSet::const_iterator gi;
for (gi = groups[num]->units.begin(); gi != groups[num]->units.end(); ++gi) {
selectedUnits.AddUnit(*gi);
}
return;
}
else if (keys[SDLK_LALT] || keys[SDLK_LMETA]) {
// do not select the group, just toggle its members with the current selection
const CUnitSet& selUnits = selectedUnits.selectedUnits;
CUnitSet::const_iterator gi;
for (gi = groups[num]->units.begin(); gi != groups[num]->units.end(); ++gi) {
if (selUnits.find(*gi) == selUnits.end()) {
selectedUnits.AddUnit(*gi);
} else {
selectedUnits.RemoveUnit(*gi);
}
}
return;
}
if(selectedUnits.selectedGroup==num && !groups[num]->units.empty()){
float3 p(0,0,0);
for(CUnitSet::iterator gi=groups[num]->units.begin();gi!=groups[num]->units.end();++gi){
p+=(*gi)->pos;
}
p/=groups[num]->units.size();
camHandler->GetCurrentController().SetPos(p);
}
selectedUnits.SelectGroup(num);
}
示例6: GML_RECMUTEX_LOCK
void CFeatureDrawer::Draw()
{
ISky::SetupFog();
GML_RECMUTEX_LOCK(feat); // Draw
CBaseGroundDrawer* gd = readmap->GetGroundDrawer();
if (gd->DrawExtraTex()) {
glActiveTextureARB(GL_TEXTURE2_ARB);
glEnable(GL_TEXTURE_2D);
glTexEnvi(GL_TEXTURE_ENV, GL_COMBINE_RGB_ARB, GL_ADD_SIGNED_ARB);
glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_COMBINE_ARB);
SetTexGen(1.0f / (gs->pwr2mapx * SQUARE_SIZE), 1.0f / (gs->pwr2mapy * SQUARE_SIZE), 0.0f, 0.0f);
glBindTexture(GL_TEXTURE_2D, gd->infoTex);
glActiveTextureARB(GL_TEXTURE0_ARB);
}
unitDrawer->SetupForUnitDrawing();
GetVisibleFeatures(0, true);
for (int modelType = MODELTYPE_3DO; modelType < MODELTYPE_OTHER; modelType++) {
opaqueModelRenderers[modelType]->PushRenderState();
DrawOpaqueFeatures(modelType);
opaqueModelRenderers[modelType]->PopRenderState();
}
unitDrawer->CleanUpUnitDrawing();
farTextureHandler->Draw();
if (gd->DrawExtraTex()) {
glActiveTextureARB(GL_TEXTURE2_ARB);
glDisable(GL_TEXTURE_2D);
glDisable(GL_TEXTURE_GEN_S);
glDisable(GL_TEXTURE_GEN_T);
glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE);
glActiveTextureARB(GL_TEXTURE0_ARB);
}
glDisable(GL_TEXTURE_2D);
glDisable(GL_FOG);
#ifdef USE_GML
DrawFeatureStats();
#endif
}
示例7: GML_RECMUTEX_LOCK
CGroup* CGroupHandler::CreateNewGroup()
{
GML_RECMUTEX_LOCK(group); // GroupCommand
if (freeGroups.empty()) {
CGroup* group = new CGroup(firstUnusedGroup++, this);
groups.push_back(group);
return group;
} else {
int id = freeGroups.back();
freeGroups.pop_back();
CGroup* group = new CGroup(id, this);
groups[id] = group;
return group;
}
}
示例8: GML_RECMUTEX_LOCK
void CWaitCommandsAI::AddTimeWait(const Command& cmd)
{
GML_RECMUTEX_LOCK(sel); // AddTimeWait
// save the current selection
const CUnitSet tmpSet = selectedUnits.selectedUnits;
CUnitSet::const_iterator it;
for (it = tmpSet.begin(); it != tmpSet.end(); ++it) {
InsertWaitObject(TimeWait::New(cmd, *it));
}
// restore the selection
selectedUnits.ClearSelected();
for (it = tmpSet.begin(); it != tmpSet.end(); ++it) {
selectedUnits.AddUnit(*it);
}
}
示例9: assert
void CQuadField::AddProjectile(CProjectile* p)
{
assert(p->synced);
GML_RECMUTEX_LOCK(quad); // AddProjectile
CProjectile::QuadFieldCellData qfcd;
typedef CQuadField::Quad Cell;
typedef std::list<CProjectile*> List;
if (p->hitscan) {
// all coordinates always map to a valid quad
qfcd.SetCoor(0, int2(CELL_IDX_X(p->pos.x ), CELL_IDX_Z(p->pos.z )));
qfcd.SetCoor(1, int2(CELL_IDX_X(p->pos.x + p->speed.x * 0.5f), CELL_IDX_Z(p->pos.z + p->speed.z * 0.5f)));
qfcd.SetCoor(2, int2(CELL_IDX_X(p->pos.x + p->speed.x ), CELL_IDX_Z(p->pos.z + p->speed.z )));
Cell& cell = baseQuads[numQuadsX * qfcd.GetCoor(0).y + qfcd.GetCoor(0).x];
List& list = cell.projectiles;
// projectiles are point-objects so they exist
// only in a single cell EXCEPT hit-scan types
qfcd.SetIter(0, list.insert(list.end(), p));
for (unsigned int n = 1; n < 3; n++) {
Cell& ncell = baseQuads[numQuadsX * qfcd.GetCoor(n).y + qfcd.GetCoor(n).x];
List& nlist = ncell.projectiles;
// prevent possible double insertions (into the same quad-list)
// if case p->speed is not large enough to reach adjacent quads
if (qfcd.GetCoor(n) != qfcd.GetCoor(n - 1)) {
qfcd.SetIter(n, nlist.insert(nlist.end(), p));
} else {
qfcd.SetIter(n, nlist.end());
}
}
} else {
qfcd.SetCoor(0, int2(CELL_IDX_X(p->pos.x), CELL_IDX_Z(p->pos.z)));
Cell& cell = baseQuads[numQuadsX * qfcd.GetCoor(0).y + qfcd.GetCoor(0).x];
List& list = cell.projectiles;
qfcd.SetIter(0, list.insert(list.end(), p));
}
p->SetQuadFieldCellData(qfcd);
}
示例10: glPushAttrib
void CFeatureDrawer::DrawFadeFeatures(bool noAdvShading)
{
const bool oldAdvShading = unitDrawer->advShading;
{
unitDrawer->advShading = unitDrawer->advShading && !noAdvShading;
if (unitDrawer->advShading) {
unitDrawer->SetupForUnitDrawing();
} else {
unitDrawer->SetupForGhostDrawing();
}
glPushAttrib(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
glDepthMask(GL_TRUE);
glEnable(GL_ALPHA_TEST);
glAlphaFunc(GL_GREATER, 0.5f);
if (globalRendering->drawFog) {
glEnable(GL_FOG);
glFogfv(GL_FOG_COLOR, mapInfo->atmosphere.fogColor);
}
{
GML_RECMUTEX_LOCK(feat); // DrawFadeFeatures
for (int modelType = MODELTYPE_3DO; modelType < MODELTYPE_OTHER; modelType++) {
cloakedModelRenderers[modelType]->PushRenderState();
DrawFadeFeaturesHelper(modelType);
cloakedModelRenderers[modelType]->PopRenderState();
}
}
glDisable(GL_FOG);
glPopAttrib();
if (unitDrawer->advShading) {
unitDrawer->CleanUpUnitDrawing();
} else {
unitDrawer->CleanUpGhostDrawing();
}
unitDrawer->advShading = oldAdvShading;
}
}
示例11: glDisable
void CFeatureDrawer::DrawShadowPass()
{
glDisable(GL_CULL_FACE); //FIXME: enable culling for s3o models
glPolygonOffset(1.0f, 1.0f);
glEnable(GL_POLYGON_OFFSET_FILL);
Shader::IProgramObject* po =
shadowHandler->GetShadowGenProg(CShadowHandler::SHADOWGEN_PROGRAM_MODEL);
po->Enable();
{
GML_RECMUTEX_LOCK(feat); // DrawShadowPass
// note: for the shadow-pass, we want to make sure
// out-of-view features casting frustum-intersecting
// shadows are still rendered, but this is expensive
// and does not make much difference
//
// GetVisibleFeatures(1, false);
// need the alpha-mask for transparent features
glEnable(GL_TEXTURE_2D);
glPushAttrib(GL_COLOR_BUFFER_BIT);
glEnable(GL_ALPHA_TEST);
glAlphaFunc(GL_GREATER, 0.5f);
// needed for 3do models (else they will use any currently bound texture)
// note: texture0 is by default a 1x1 texture with rgba(0,0,0,255)
// (we are just interested in the 255 alpha here)
glBindTexture(GL_TEXTURE_2D, 0);
for (int modelType = MODELTYPE_3DO; modelType < MODELTYPE_OTHER; modelType++) {
DrawOpaqueFeatures(modelType);
}
glPopAttrib();
glDisable(GL_TEXTURE_2D);
}
po->Disable();
glDisable(GL_POLYGON_OFFSET_FILL);
glEnable(GL_CULL_FACE);
}
示例12: GML_RECMUTEX_LOCK
float CGameHelper::GuiTraceRayFeature(const float3& start, const float3& dir, float length, CFeature*& feature)
{
float nearHit = length;
GML_RECMUTEX_LOCK(quad); // GuiTraceRayFeature
std::vector<int> quads = qf->GetQuadsOnRay(start, dir, length);
std::vector<int>::iterator qi;
for (qi = quads.begin(); qi != quads.end(); ++qi) {
const CQuadField::Quad& quad = qf->GetQuad(*qi);
std::list<CFeature*>::const_iterator ui;
// NOTE: switch this to custom volumes fully?
// (not used for any LOF checks, maybe wasteful)
for (ui = quad.features.begin(); ui != quad.features.end(); ++ui) {
CFeature* f = *ui;
if (!gu->spectatingFullView && !f->IsInLosForAllyTeam(gu->myAllyTeam)) {
continue;
}
if (f->noSelect) {
continue;
}
CollisionVolume* cv = f->collisionVolume;
const float3& midPosOffset = cv? cv->GetOffsets(): ZeroVector;
const float3 dif = (f->midPos + midPosOffset) - start;
float closeLength = dif.dot(dir);
if (closeLength < 0)
continue;
if (closeLength > nearHit)
continue;
float3 closeVect = dif - dir * closeLength;
if (closeVect.SqLength() < f->sqRadius) {
nearHit = closeLength;
feature = f;
}
}
}
return nearHit;
}
示例13: GML_RECMUTEX_LOCK
CGroup* CGroupHandler::CreateNewGroup()
{
GML_RECMUTEX_LOCK(group); // GroupCommand
if(freeGroups.empty()){
CGroup* group=new CGroup(firstUnusedGroup++, this);
groups.push_back(group);
if(group!=groups[group->id]){
handleerror(0,"Id error when creating group","Error",0);
}
return group;
} else {
int id=freeGroups.back();
freeGroups.pop_back();
CGroup* group=new CGroup(id, this);
groups[id]=group;
return group;
}
}
示例14: glPushAttrib
void CFeatureDrawer::DrawFadeFeatures(bool noAdvShading)
{
const bool oldAdvShading = unitDrawer->UseAdvShading();
{
unitDrawer->SetUseAdvShading(unitDrawer->UseAdvShading() && !noAdvShading);
if (unitDrawer->UseAdvShading()) {
unitDrawer->SetupForUnitDrawing(false);
} else {
unitDrawer->SetupForGhostDrawing();
}
glPushAttrib(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
glDepthMask(GL_TRUE);
glEnable(GL_ALPHA_TEST);
glAlphaFunc(GL_GREATER, 0.5f);
ISky::SetupFog();
{
GML_RECMUTEX_LOCK(feat); // DrawFadeFeatures
for (int modelType = MODELTYPE_3DO; modelType < MODELTYPE_OTHER; modelType++) {
cloakedModelRenderers[modelType]->PushRenderState();
DrawFadeFeaturesHelper(modelType);
cloakedModelRenderers[modelType]->PopRenderState();
}
}
glDisable(GL_FOG);
glPopAttrib();
if (unitDrawer->UseAdvShading()) {
unitDrawer->CleanUpUnitDrawing(false);
} else {
unitDrawer->CleanUpGhostDrawing();
}
unitDrawer->SetUseAdvShading(oldAdvShading);
}
}
示例15: GML_RECMUTEX_LOCK
void CSelectedUnits::SendCommand(const Command& c)
{
if (selectionChanged) {
// send new selection
GML_RECMUTEX_LOCK(sel); // SendSelection
// first, convert CUnit* to unit IDs.
std::vector<short> selectedUnitIDs(selectedUnits.size());
std::vector<short>::iterator i = selectedUnitIDs.begin();
CUnitSet::const_iterator ui = selectedUnits.begin();
for(; ui != selectedUnits.end(); ++i, ++ui) {
*i = (*ui)->id;
}
net->Send(CBaseNetProtocol::Get().SendSelect(gu->myPlayerNum, selectedUnitIDs));
selectionChanged = false;
}
net->Send(CBaseNetProtocol::Get().SendCommand(gu->myPlayerNum, c.GetID(), c.options, c.params));
}