blob: 00b86823f89f0a6496ccf70b227e72df1a312411 (
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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
|
/*************************************************************************
* Copyright (C) 2009-2010 Tavian Barnes <tavianator@gmail.com> *
* *
* This file is part of The Dimension Library. *
* *
* The Dimension Library is free software; you can redistribute it and/ *
* or modify it under the terms of the GNU Lesser General Public License *
* as published by the Free Software Foundation; either version 3 of the *
* License, or (at your option) any later version. *
* *
* The Dimension Library is distributed in the hope that it will be *
* useful, but WITHOUT ANY WARRANTY; without even the implied warranty *
* of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
* Lesser General Public License for more details. *
* *
* You should have received a copy of the GNU Lesser General Public *
* License along with this program. If not, see *
* <http://www.gnu.org/licenses/>. *
*************************************************************************/
#include "dimension.h"
#include <stdlib.h>
/* Allocate a dummy pigment */
dmnsn_pigment *
dmnsn_new_pigment()
{
dmnsn_pigment *pigment = dmnsn_malloc(sizeof(dmnsn_pigment));
pigment->pigment_fn = NULL;
pigment->init_fn = NULL;
pigment->free_fn = NULL;
pigment->trans = dmnsn_identity_matrix();
pigment->quick_color = dmnsn_black;
return pigment;
}
/* Free a pigment */
void
dmnsn_delete_pigment(dmnsn_pigment *pigment)
{
if (pigment) {
if (pigment->free_fn) {
(*pigment->free_fn)(pigment->ptr);
}
dmnsn_free(pigment);
}
}
/* Precompute pigment properties */
void
dmnsn_pigment_init(dmnsn_pigment *pigment)
{
if (pigment->init_fn) {
(*pigment->init_fn)(pigment);
}
pigment->trans_inv = dmnsn_matrix_inverse(pigment->trans);
}
/* Allocate a dummy finish */
dmnsn_finish *
dmnsn_new_finish()
{
dmnsn_finish *finish = dmnsn_malloc(sizeof(dmnsn_finish));
finish->diffuse_fn = NULL;
finish->specular_fn = NULL;
finish->ambient_fn = NULL;
finish->reflection_fn = NULL;
finish->free_fn = NULL;
return finish;
}
/* Free a finish */
void
dmnsn_delete_finish(dmnsn_finish *finish)
{
if (finish) {
if (finish->free_fn) {
(*finish->free_fn)(finish->ptr);
}
dmnsn_free(finish);
}
}
/* Allocate a dummy texture */
dmnsn_texture *
dmnsn_new_texture()
{
dmnsn_texture *texture = dmnsn_malloc(sizeof(dmnsn_texture));
texture->pigment = NULL;
texture->finish = NULL;
texture->trans = dmnsn_identity_matrix();
texture->refcount = dmnsn_malloc(sizeof(unsigned int));
*texture->refcount = 1;
texture->should_init = true;
return texture;
}
/* Free a texture */
void
dmnsn_delete_texture(dmnsn_texture *texture)
{
if (texture) {
if (*texture->refcount <= 1) {
dmnsn_delete_finish(texture->finish);
dmnsn_delete_pigment(texture->pigment);
dmnsn_free(texture->refcount);
dmnsn_free(texture);
} else {
--*texture->refcount;
}
}
}
/* Calculate matrix inverses */
void
dmnsn_texture_init(dmnsn_texture *texture)
{
texture->trans_inv = dmnsn_matrix_inverse(texture->trans);
if (texture->pigment) {
texture->pigment->trans
= dmnsn_matrix_mul(texture->trans, texture->pigment->trans);
dmnsn_pigment_init(texture->pigment);
}
}
|