本文整理汇总了C++中Chunk::GetX方法的典型用法代码示例。如果您正苦于以下问题:C++ Chunk::GetX方法的具体用法?C++ Chunk::GetX怎么用?C++ Chunk::GetX使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Chunk
的用法示例。
在下文中一共展示了Chunk::GetX方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: DoCollision
void ItemEntity::DoCollision(World* world, double deltaTime) {
m_pos.x += m_motion.x;
m_pos.y += m_motion.y;
int toprightX = (int)(m_pos.x - m_size.x / 2.0);
int toprightY = (int)(m_pos.y - m_size.y / 2.0);
Chunk* chunkPtr = world->GetChunkAt(toprightX / (Chunk::TILESIZE*Chunk::SIZE), toprightY / (Chunk::TILESIZE*Chunk::SIZE));
if (chunkPtr == nullptr) {
m_motion.y += 1 * deltaTime;
return;
}
int blockposX = toprightX / (Chunk::TILESIZE) - chunkPtr->GetX()*Chunk::SIZE;
int blockposY = (toprightY + m_size.y/2.0) / (Chunk::TILESIZE) - chunkPtr->GetY()*Chunk::SIZE;
Tile* tilePtr = chunkPtr->GetTileAt(blockposX, blockposY);
double topRightLocX = toprightX - chunkPtr->GetX()* Chunk::TILESIZE* Chunk::SIZE;
double topRightLocY = toprightY - chunkPtr->GetY()* Chunk::TILESIZE* Chunk::SIZE;
if (tilePtr != nullptr) {
if (tilePtr->type != Chunk::Type::AIR) {
m_pos.y = blockposY * Chunk::TILESIZE + chunkPtr->GetY()* Chunk::TILESIZE* Chunk::SIZE - m_size.y / 2;
m_motion.y = 0;
} else {
m_motion.y += 1 * deltaTime;
}
}
}
示例2: CreateImage
// Create image saved in file
int Level::CreateImage(const STRING & file)
{
if (cancel)
return LVL_ERR_CANCEL;
state = CREATEIMAGE;
if (chunks.empty())
return LVL_ERR_NOCHUNKS;
INT64 minX = MAPCOORD;
INT64 minY = MAPCOORD;
INT64 maxX = -MAPCOORD;
INT64 maxY = -MAPCOORD;
blocks = chunks.size() << 8;
bool doRender = !(prefs.flags & CHUNKP_NORENDER);
// Calculate size
for (list<Chunk *>::iterator i = chunks.begin(); i != chunks.end(); ++i)
{
Chunk * chunk = (*i);
if (!chunk->isValid())
continue;
if (doRender)
{
COORDS x = chunk->GetX();
COORDS y = chunk->GetY();
if (x < minX)
minX = x;
if (y < minY)
minY = y;
if (x > maxX)
maxX = x;
if (y > maxY)
maxY = y;
}
// And add to amount while we are processing
amount += chunk->amount;
}
if (cancel)
return LVL_ERR_CANCEL;
if (doRender)
{
// No valid chunks?
if (minX == MAPCOORD && minY == MAPCOORD &&
maxX == -MAPCOORD && maxY == -MAPCOORD)
return LVL_ERR_INVALIDCHUNKS;
prefs.rotation = abs((prefs.rotation / 90) * 90) % 360;
float rad = (2 * 3.14159265f * prefs.rotation) / 360;
UINT
maxWidth = (UINT)(maxX - minX),
maxHeight = (UINT)(maxY - minY);
UINT
width = (maxWidth + 1) * MAPX,
height = (maxHeight + 1) * MAPY;
// Foolproof
if (width == 0 || height == 0)
return LVL_ERR_INVALIDSIZE;
// Rotate
{
float rCos = cos(rad);
float rSin = sin(rad);
rCos = (rCos < 0) ? -rCos : rCos;
rSin = (rSin < 0) ? -rSin : rSin;
UINT newWidth = UINT(width * rCos + height * rSin);
UINT newHeight = UINT(height * rCos + width * rSin);
width = newWidth;
height = newHeight;
}
// Foolproof
if (width == 0 || height == 0)
return LVL_ERR_INVALIDSIZE;
bool useCache = !prefs.cache.empty();
ImageCache cache(height, width);
Image * image = 0;
if (!useCache)
{
#ifndef min
#define min(a,b) (((a) < (b)) ? (a) : (b))
#endif
// No more than 1 GiB
if (width * height * sizeof(Color) > min(1073741824, Computer::GetAvailableMemory()))
return LVL_ERR_TOOLARGE;
try
{
image = new Image(height, width);
if (image == 0)
throw LVL_ERR_TOOLARGE;
}
catch (Level_Error error)
//.........这里部分代码省略.........