-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathCollisionFuncs.h
60 lines (52 loc) · 1.76 KB
/
CollisionFuncs.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#pragma once
// Assigns and returns a layer's collision tileset before checking for
// collisions
cSurface * prepareLayerCollSurf(LPRDATA rdPtr, const Layer & layer)
{
// Get layer's collision tileset
unsigned char tilesetID = (layer.settings.collision != 0xff) ? layer.settings.collision
: layer.settings.tileset;
if (tilesetID >= rdPtr->p->tilesets->size())
return 0;
rdPtr->cndTileset = &(*rdPtr->p->tilesets)[tilesetID];
// Get tileset's settings
return rdPtr->cndTileset->surface;
}
// Prepares a fine collision by locking the used buffer
BYTE * prepareFineColl(LPRDATA rdPtr, cSurface * surface)
{
if (!rdPtr->fineColl)
return 0;
if (surface->HasAlpha()) {
rdPtr->cndAlphaSurf = surface->GetAlphaSurface();
return rdPtr->cndAlphaSurf->LockBuffer();
}
else {
return surface->LockBuffer();
}
}
// Unlocks the buffer
void unprepareFineColl(LPRDATA rdPtr, cSurface * surface, BYTE * buff)
{
if (!rdPtr->fineColl)
return;
if (surface->HasAlpha()) {
rdPtr->cndAlphaSurf->UnlockBuffer(buff);
surface->ReleaseAlphaSurface(rdPtr->cndAlphaSurf);
}
else {
surface->UnlockBuffer(buff);
}
}
// Caches all sub-layer pointers that will be needed for the overlap filters
void cacheOverlapSublayers(LPRDATA rdPtr, const Layer & layer)
{
// If there's a sublayer filter we'll cache the layer's sublayer pointers
for (unsigned i = 0; i < rdPtr->ovlpFilterCount; ++i) {
if (rdPtr->ovlpFilters[i].type == OFT_SUBLAYER) {
unsigned sub = rdPtr->ovlpFilters[i].param;
if (sub <= 16)
rdPtr->sublayerCache[sub] = &layer.subLayers[sub];
}
}
}