File: TerrainVertexBuffer.h

package info (click to toggle)
spring 0.81.2.1%2Bdfsg1-6
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 28,496 kB
  • ctags: 37,096
  • sloc: cpp: 238,659; ansic: 13,784; java: 12,175; awk: 3,428; python: 1,159; xml: 738; perl: 405; sh: 297; makefile: 267; pascal: 228; objc: 192
file content (68 lines) | stat: -rw-r--r-- 2,110 bytes parent folder | download
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
/*
---------------------------------------------------------------------
   Terrain Renderer using texture splatting and geomipmapping
   Copyright (c) 2006 Jelmer Cnossen

   This software is provided 'as-is', without any express or implied
   warranty. In no event will the authors be held liable for any
   damages arising from the use of this software.

   Permission is granted to anyone to use this software for any
   purpose, including commercial applications, and to alter it and
   redistribute it freely, subject to the following restrictions:

   1. The origin of this software must not be misrepresented; you
      must not claim that you wrote the original software. If you use
      this software in a product, an acknowledgment in the product
      documentation would be appreciated but is not required.

   2. Altered source versions must be plainly marked as such, and
      must not be misrepresented as being the original software.

   3. This notice may not be removed or altered from any source
      distribution.

   Jelmer Cnossen
   j.cnossen at gmail dot com
---------------------------------------------------------------------
*/
#ifndef JC_TERRAIN_VERTEX_BUFFER_H
#define JC_TERRAIN_VERTEX_BUFFER_H

namespace terrain {

	class VertexBuffer
	{
	public:
		VertexBuffer ();
		~VertexBuffer ();

		void Init(int bytesize); /// Allocate the buffer
		void Free(); /// Free the buffer, called by destructor
		uint GetSize() { return size; } /// returns the vertex buffer size in bytes

		void* Bind (); /// returns the pointer that should be passed to glVertexPointer
		void Unbind (); /// unbind it, so it can be locked again

		void* LockData(); /// returns a pointer to the data, write-only
		void UnlockData(); /// unlocks the data, so it can be used for rendering
		
		static int TotalSize() { return totalBufferSize; } /// returns total buffer memory size used by all VertexBuffer instances

	protected:
		char *data;
		GLuint id;
		uint size;
		uint type;

		static int totalBufferSize;
	};

	class IndexBuffer : public VertexBuffer
	{
	public:
		IndexBuffer ();
	};
};

#endif