[ChunkLightmap] No longer dependent on BlockType.

This commit is contained in:
Quentin Bazin 2020-02-03 15:49:09 +09:00
parent 9afa1b6202
commit 83832bb136
3 changed files with 18 additions and 19 deletions

View File

@ -88,7 +88,7 @@ std::array<std::size_t, ChunkBuilder::layers> ChunkBuilder::buildChunk(const Cli
};
if (block.drawType() == BlockDrawType::Solid
|| block.drawType() == BlockDrawType::AllFaces
|| block.drawType() == BlockDrawType::Leaves
|| block.drawType() == BlockDrawType::Liquid
|| block.drawType() == BlockDrawType::Glass) {
for(u8 i = 0 ; i < 6 ; i++) {

View File

@ -31,11 +31,11 @@ class Player;
class World;
enum class BlockDrawType {
Solid = 0,
XShape = 1,
AllFaces = 2,
Liquid = 3,
Glass = 4,
Solid = 0,
XShape = 1,
Leaves = 2,
Liquid = 3,
Glass = 4,
};
class Block : public ISerializable {

View File

@ -120,8 +120,8 @@ bool ChunkLightmap::updateTorchlight() {
// If this block is opaque, don't propagate the light
// u16 block = m_chunk->getBlock(node.x, node.y, node.z);
// if (!(!block || block == BlockType::Water || block == BlockType::Glass || block == BlockType::Flower
// /* || !Registry::getInstance().getBlock(block).isOpaque() */)) { // FIXME
// const Block &block = Registry::getInstance().getBlock(blockID);
// if (block.isOpaque() || block.drawType() == BlockDrawType::Leaves) {
// setTorchlight(node.x, node.y, node.z, 0);
//
// lightUpdated = true; // FIXME
@ -141,9 +141,9 @@ bool ChunkLightmap::updateTorchlight() {
u8 lightLevel = getTorchlight(node.x, node.y, node.z);
for (const gk::Vector3i &surroundingNode : surroundingNodes) {
if (getTorchlight(surroundingNode.x, surroundingNode.y, surroundingNode.z) + 2 <= lightLevel) {
u16 block = m_chunk->getBlock(surroundingNode.x, surroundingNode.y, surroundingNode.z);
if (!block || block == BlockType::Water || block == BlockType::Glass || block == BlockType::Flower
/* || !Registry::getInstance().getBlock(block).isOpaque() */) { // FIXME
u16 blockID = m_chunk->getBlock(surroundingNode.x, surroundingNode.y, surroundingNode.z);
const Block &block = Registry::getInstance().getBlock(blockID);
if (!block.isOpaque() && block.drawType() != BlockDrawType::Leaves) {
addTorchlight(surroundingNode.x, surroundingNode.y, surroundingNode.z, lightLevel - 1);
lightUpdated = true;
@ -193,9 +193,9 @@ bool ChunkLightmap::updateSunlight() {
m_sunlightBfsQueue.pop();
// If this block is opaque, don't propagate the light
u16 block = m_chunk->getBlock(node.x, node.y, node.z);
if (!(!block || block == BlockType::Water || block == BlockType::Glass || block == BlockType::Flower
/* || !Registry::getInstance().getBlock(block).isOpaque() */)) { // FIXME
u16 blockID = m_chunk->getBlock(node.x, node.y, node.z);
const Block &block = Registry::getInstance().getBlock(blockID);
if (block.isOpaque() || block.drawType() == BlockDrawType::Leaves) {
setSunlight(node.x, node.y, node.z, 0);
// FIXME: This only reverts an addSunlight that added light in a non-generated chunk
@ -219,11 +219,10 @@ bool ChunkLightmap::updateSunlight() {
u8 neighbourSunlightLevel = getSunlight(surroundingNode.x, surroundingNode.y, surroundingNode.z);
if (neighbourSunlightLevel + 2 <= sunlightLevel
|| (sunlightLevel == 15 && neighbourSunlightLevel != 15 && surroundingNode.y == node.y - 1)) {
u16 block = m_chunk->getBlock(surroundingNode.x, surroundingNode.y, surroundingNode.z);
if (!block || block == BlockType::Water || block == BlockType::Glass || block == BlockType::Flower
/* || !Registry::getInstance().getBlock(block).isOpaque() */) { // FIXME
if (sunlightLevel == 15 && surroundingNode.y == node.y - 1) {
u16 blockID = m_chunk->getBlock(surroundingNode.x, surroundingNode.y, surroundingNode.z);
const Block &block = Registry::getInstance().getBlock(blockID);
if (!block.isOpaque() && block.drawType() != BlockDrawType::Leaves) {
if (sunlightLevel == 15 && surroundingNode.y == node.y - 1 && (!blockID || block.drawType() == BlockDrawType::Glass)) {
addSunlight(surroundingNode.x, surroundingNode.y, surroundingNode.z, sunlightLevel);
lightUpdated = true;