2016-11-29 16:11:53 -06:00
|
|
|
package pixelgl
|
|
|
|
|
2016-12-15 17:28:52 -06:00
|
|
|
// AttrFormat defines names and types of OpenGL attributes (vertex format, uniform format, etc.).
|
|
|
|
//
|
|
|
|
// Example:
|
2017-01-13 17:47:49 -06:00
|
|
|
// AttrFormat{{"position", Vec2}, {"color", Vec4}, {"texCoord": Vec2}}
|
|
|
|
type AttrFormat []Attr
|
2016-11-29 16:11:53 -06:00
|
|
|
|
2016-12-15 17:28:52 -06:00
|
|
|
// Size returns the total size of all attributes of an attribute format.
|
|
|
|
func (af AttrFormat) Size() int {
|
|
|
|
total := 0
|
2017-01-13 17:47:49 -06:00
|
|
|
for _, attr := range af {
|
|
|
|
total += attr.Type.Size()
|
2016-12-15 17:28:52 -06:00
|
|
|
}
|
|
|
|
return total
|
|
|
|
}
|
2016-11-29 16:11:53 -06:00
|
|
|
|
2016-12-30 10:53:47 -06:00
|
|
|
// Attr represents an arbitrary OpenGL attribute, such as a vertex attribute or a shader
|
|
|
|
// uniform attribute.
|
2016-12-15 17:28:52 -06:00
|
|
|
type Attr struct {
|
|
|
|
Name string
|
|
|
|
Type AttrType
|
|
|
|
}
|
2016-11-29 16:11:53 -06:00
|
|
|
|
|
|
|
// AttrType represents the type of an OpenGL attribute.
|
|
|
|
type AttrType int
|
|
|
|
|
|
|
|
// List of all possible attribute types.
|
|
|
|
const (
|
2016-12-01 09:09:56 -06:00
|
|
|
Int AttrType = iota
|
2016-11-29 16:11:53 -06:00
|
|
|
Float
|
|
|
|
Vec2
|
|
|
|
Vec3
|
|
|
|
Vec4
|
|
|
|
Mat2
|
|
|
|
Mat23
|
|
|
|
Mat24
|
|
|
|
Mat3
|
|
|
|
Mat32
|
|
|
|
Mat34
|
|
|
|
Mat4
|
|
|
|
Mat42
|
|
|
|
Mat43
|
|
|
|
)
|
|
|
|
|
|
|
|
// Size returns the size of a type in bytes.
|
|
|
|
func (at AttrType) Size() int {
|
2016-12-19 16:50:14 -06:00
|
|
|
switch at {
|
|
|
|
case Int:
|
|
|
|
return 4
|
|
|
|
case Float:
|
|
|
|
return 4
|
|
|
|
case Vec2:
|
|
|
|
return 2 * 4
|
|
|
|
case Vec3:
|
|
|
|
return 3 * 4
|
|
|
|
case Vec4:
|
|
|
|
return 4 * 4
|
|
|
|
case Mat2:
|
|
|
|
return 2 * 2 * 4
|
|
|
|
case Mat23:
|
|
|
|
return 2 * 3 * 4
|
|
|
|
case Mat24:
|
|
|
|
return 2 * 4 * 4
|
|
|
|
case Mat3:
|
|
|
|
return 3 * 3 * 4
|
|
|
|
case Mat32:
|
|
|
|
return 3 * 2 * 4
|
|
|
|
case Mat34:
|
|
|
|
return 3 * 4 * 4
|
|
|
|
case Mat4:
|
|
|
|
return 4 * 4 * 4
|
|
|
|
case Mat42:
|
|
|
|
return 4 * 2 * 4
|
|
|
|
case Mat43:
|
|
|
|
return 4 * 3 * 4
|
|
|
|
default:
|
|
|
|
panic("size of vertex attribute type: invalid type")
|
|
|
|
}
|
2016-11-29 16:11:53 -06:00
|
|
|
}
|