aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.Client/ChestRenderer.cpp
blob: d1b5cf91829677d65c7dba88a90c69af0b24805f (plain)
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
#include "stdafx.h"
#include "ChestRenderer.h"
#include "ChestModel.h"
#include "LargeChestModel.h"
#include "ModelPart.h"
#include "..\Minecraft.World\net.minecraft.world.level.tile.entity.h"
#include "..\Minecraft.World\net.minecraft.world.level.tile.h"

ChestRenderer::ChestRenderer()
{
	chestModel = new ChestModel();
	largeChestModel = new LargeChestModel();
}

ChestRenderer::~ChestRenderer()
{
	delete chestModel;
	delete largeChestModel;
}

void ChestRenderer::render(shared_ptr<TileEntity>  _chest, double x, double y, double z, float a, bool setColor, float alpha, bool useCompiled)
{
	// 4J Convert as we aren't using a templated class
	shared_ptr<ChestTileEntity> chest = dynamic_pointer_cast<ChestTileEntity>(_chest);

	int data;

	if (!chest->hasLevel())
	{
		data = 0;
	}
	else
	{
		Tile *tile = chest->getTile();
		data = chest->getData();

		if (tile != NULL && data == 0)
		{
			((ChestTile *) tile)->recalcLockDir(chest->getLevel(), chest->x, chest->y, chest->z);
			data = chest->getData();
		}

		chest->checkNeighbors();
	}
	if (chest->n.lock() != NULL || chest->w.lock() != NULL) return;


	ChestModel *model;
	if (chest->e.lock() != NULL || chest->s.lock() != NULL)
	{
		model = largeChestModel;
		bindTexture(TN_TILE_LARGE_CHEST); // 4J Was "/item/largechest.png"
	}
	else
	{
		model = chestModel;
		bindTexture(TN_TILE_CHEST); // 4J Was "/item/chest.png"
	}

	glPushMatrix();
	glEnable(GL_RESCALE_NORMAL);
	//if( setColor ) glColor4f(1, 1, 1, 1);
	if( setColor ) glColor4f(1, 1, 1, alpha);
	glTranslatef((float) x, (float) y + 1, (float) z + 1);
	glScalef(1, -1, -1);

	glTranslatef(0.5f, 0.5f, 0.5f);
	int rot = 0;
	if (data == 2) rot = 180;
	if (data == 3) rot = 0;
	if (data == 4) rot = 90;
	if (data == 5) rot = -90;

	if (data == 2 && chest->e.lock() != NULL)
	{
		glTranslatef(1, 0, 0);
	}
	if (data == 5 && chest->s.lock() != NULL)
	{
		glTranslatef(0, 0, -1);
	}
	glRotatef(rot, 0, 1, 0);
	glTranslatef(-0.5f, -0.5f, -0.5f);

	float open = chest->oOpenness + (chest->openness - chest->oOpenness) * a;
	if (chest->n.lock() != NULL)
	{
		float open2 = chest->n.lock()->oOpenness + (chest->n.lock()->openness - chest->n.lock()->oOpenness) * a;
		if (open2 > open) open = open2;
	}
	if (chest->w.lock() != NULL)
	{
		float open2 = chest->w.lock()->oOpenness + (chest->w.lock()->openness - chest->w.lock()->oOpenness) * a;
		if (open2 > open) open = open2;
	}

	open = 1 - open;
	open = 1 - open * open * open;

	model->lid->xRot = -(open * PI / 2);
	model->render(useCompiled);
	glDisable(GL_RESCALE_NORMAL);
	glPopMatrix();
	if( setColor ) glColor4f(1, 1, 1, 1);
}