aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.Client/ArrowRenderer.cpp
blob: a7dd6efdd78110baa81a81f3e60296123cbe215e (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
#include "stdafx.h"
#include "ArrowRenderer.h"
#include "..\Minecraft.World\net.minecraft.world.entity.projectile.h"
#include "..\Minecraft.World\Mth.h"

ResourceLocation ArrowRenderer::ARROW_LOCATION = ResourceLocation(TN_ITEM_ARROWS);

void ArrowRenderer::render(shared_ptr<Entity> _arrow, double x, double y, double z, float rot, float a)
{
	// 4J - original version used generics and thus had an input parameter of type Arrow rather than shared_ptr<Entity>  we have here - 
	// do some casting around instead
	shared_ptr<Arrow> arrow = dynamic_pointer_cast<Arrow>(_arrow);
    bindTexture(_arrow); // 4J - was L"/item/arrows.png"

    glPushMatrix();

	float yRot = arrow->yRot;
	float xRot = arrow->xRot;
	float yRotO = arrow->yRotO;
	float xRotO = arrow->xRotO;
	if( ( yRot - yRotO ) > 180.0f ) yRot -= 360.0f;
	else if( ( yRot - yRotO ) < -180.0f ) yRot += 360.0f;
	if( ( xRot - xRotO ) > 180.0f ) xRot -= 360.0f;
	else if( ( xRot - xRotO ) < -180.0f ) xRot += 360.0f;

    glTranslatef(static_cast<float>(x), static_cast<float>(y), static_cast<float>(z));
    glRotatef(yRotO + (yRot - yRotO) * a - 90, 0, 1, 0);
    glRotatef(xRotO + (xRot - xRotO) * a, 0, 0, 1);

    Tesselator *t = Tesselator::getInstance();
    int type = 0;

    float u0 = 0 / 32.0f;
    float u1 = 16 / 32.0f;
    float v0 = (0 + type * 10) / 32.0f;
    float v1 = (5 + type * 10) / 32.0f;

    float u02 = 0 / 32.0f;
    float u12 = 5 / 32.0f;
    float v02 = (5 + type * 10) / 32.0f;
    float v12 = (10 + type * 10) / 32.0f;
    float ss = 0.9f / 16.0f;
    glEnable(GL_RESCALE_NORMAL);
    float shake = arrow->shakeTime-a;
    if (shake>0)
    {
        float pow = -Mth::sin(shake*3)*shake;
        glRotatef(pow, 0, 0, 1);
    }
    glRotatef(45, 1, 0, 0);
    glScalef(ss, ss, ss);

    glTranslatef(-4, 0, 0);

//    glNormal3f(ss, 0, 0);		// 4J - changed to use tesselator
    t->begin();
	t->normal(1,0,0);
    t->vertexUV(static_cast<float>(-7), static_cast<float>(-2), static_cast<float>(-2), (float)( u02), (float)( v02));
    t->vertexUV(static_cast<float>(-7), static_cast<float>(-2), static_cast<float>(+2), (float)( u12), (float)( v02));
    t->vertexUV(static_cast<float>(-7), static_cast<float>(+2), static_cast<float>(+2), (float)( u12), (float)( v12));
    t->vertexUV(static_cast<float>(-7), static_cast<float>(+2), static_cast<float>(-2), (float)( u02), (float)( v12));
    t->end();

//    glNormal3f(-ss, 0, 0);	// 4J - changed to use tesselator
    t->begin();
	t->normal(-1,0,0);
    t->vertexUV(static_cast<float>(-7), static_cast<float>(+2), static_cast<float>(-2), (float)( u02), (float)( v02));
    t->vertexUV(static_cast<float>(-7), static_cast<float>(+2), static_cast<float>(+2), (float)( u12), (float)( v02));
    t->vertexUV(static_cast<float>(-7), static_cast<float>(-2), static_cast<float>(+2), (float)( u12), (float)( v12));
    t->vertexUV(static_cast<float>(-7), static_cast<float>(-2), static_cast<float>(-2), (float)( u02), (float)( v12));
    t->end();

    for (int i = 0; i < 4; i++)
	{

        glRotatef(90, 1, 0, 0);
//        glNormal3f(0, 0, ss);		// 4J - changed to use tesselator
        t->begin();
		t->normal(0,0,1);
        t->vertexUV(static_cast<float>(-8), static_cast<float>(-2), static_cast<float>(0), (float)( u0), (float)( v0));
        t->vertexUV(static_cast<float>(+8), static_cast<float>(-2), static_cast<float>(0), (float)( u1), (float)( v0));
        t->vertexUV(static_cast<float>(+8), static_cast<float>(+2), static_cast<float>(0), (float)( u1), (float)( v1));
        t->vertexUV(static_cast<float>(-8), static_cast<float>(+2), static_cast<float>(0), (float)( u0), (float)( v1));
        t->end();
    }
    glDisable(GL_RESCALE_NORMAL);
    glPopMatrix();
}

ResourceLocation *ArrowRenderer::getTextureLocation(shared_ptr<Entity> mob)
{
    return &ARROW_LOCATION;
}