2026-03-01 12:16:08 +08:00
|
|
|
#include "stdafx.h"
|
|
|
|
|
#include "DataLayer.h"
|
|
|
|
|
|
|
|
|
|
DataLayer::DataLayer(int length, int depthBits) : depthBits(depthBits), depthBitsPlusFour(depthBits + 4)
|
|
|
|
|
{
|
|
|
|
|
data = byteArray(length >> 1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
DataLayer::DataLayer(byteArray data, int depthBits) : depthBits(depthBits), depthBitsPlusFour(depthBits + 4)
|
|
|
|
|
{
|
|
|
|
|
this->data = data;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
DataLayer::~DataLayer()
|
|
|
|
|
{
|
|
|
|
|
delete[] data.data;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int DataLayer::get(int x, int y, int z)
|
|
|
|
|
{
|
|
|
|
|
int pos = (x << depthBitsPlusFour | z << depthBits | y);
|
|
|
|
|
int slot = pos >> 1;
|
|
|
|
|
int part = pos & 1;
|
|
|
|
|
|
|
|
|
|
if (part == 0)
|
|
|
|
|
{
|
|
|
|
|
return data[slot] & 0xf;
|
|
|
|
|
} else
|
|
|
|
|
{
|
|
|
|
|
return (data[slot] >> 4) & 0xf;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void DataLayer::set(int x, int y, int z, int val)
|
|
|
|
|
{
|
|
|
|
|
int pos = (x << depthBitsPlusFour | z << depthBits | y);
|
|
|
|
|
|
|
|
|
|
int slot = pos >> 1;
|
|
|
|
|
int part = pos & 1;
|
|
|
|
|
|
|
|
|
|
if (part == 0)
|
|
|
|
|
{
|
2026-03-08 19:08:36 -04:00
|
|
|
data[slot] = static_cast<byte>((data[slot] & 0xf0) | (val & 0xf));
|
2026-03-01 12:16:08 +08:00
|
|
|
} else
|
|
|
|
|
{
|
2026-03-08 19:08:36 -04:00
|
|
|
data[slot] = static_cast<byte>((data[slot] & 0x0f) | ((val & 0xf) << 4));
|
2026-03-01 12:16:08 +08:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool DataLayer::isValid()
|
|
|
|
|
{
|
2026-03-08 19:08:36 -04:00
|
|
|
return data.data != nullptr;
|
2026-03-01 12:16:08 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void DataLayer::setAll(int br)
|
|
|
|
|
{
|
2026-03-08 19:08:36 -04:00
|
|
|
byte val = static_cast<byte>(br & (br << 4));
|
2026-03-01 12:16:08 +08:00
|
|
|
for (unsigned int i = 0; i < data.length; i++)
|
|
|
|
|
{
|
|
|
|
|
data[i] = val;
|
|
|
|
|
}
|
|
|
|
|
}
|