GSVertexList.h
上传用户:xjjlds
上传日期:2015-12-05
资源大小:22823k
文件大小:2k
源码类别:

多媒体编程

开发平台:

Visual C++

  1. /* 
  2.  * Copyright (C) 2003-2005 Gabest
  3.  * http://www.gabest.org
  4.  *
  5.  *  This Program is free software; you can redistribute it and/or modify
  6.  *  it under the terms of the GNU General Public License as published by
  7.  *  the Free Software Foundation; either version 2, or (at your option)
  8.  *  any later version.
  9.  *   
  10.  *  This Program is distributed in the hope that it will be useful,
  11.  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
  12.  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13.  *  GNU General Public License for more details.
  14.  *   
  15.  *  You should have received a copy of the GNU General Public License
  16.  *  along with GNU Make; see the file COPYING.  If not, write to
  17.  *  the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. 
  18.  *  http://www.gnu.org/copyleft/gpl.html
  19.  *
  20.  */
  21. #pragma once
  22. template <class VERTEX> class GSVertexList
  23. {
  24. VERTEX* m_v;
  25. int m_head, m_tail, m_count;
  26. public:
  27. GSVertexList()
  28. {
  29. m_v = (VERTEX*)_aligned_malloc(sizeof(VERTEX)*4, 16);
  30. RemoveAll();
  31. }
  32. ~GSVertexList()
  33. {
  34. _aligned_free(m_v);
  35. }
  36. void RemoveAll()
  37. {
  38. m_head = m_tail = m_count = 0;
  39. }
  40. VERTEX& AddTail()
  41. {
  42. ASSERT(m_count < 4);
  43. VERTEX& v = m_v[m_tail];
  44. m_tail = (m_tail+1)&3;
  45. m_count++;
  46. return v;
  47. }
  48. void AddTail(VERTEX& v)
  49. {
  50. ASSERT(m_count < 4);
  51. m_v[m_tail] = v;
  52. m_tail = (m_tail+1)&3;
  53. m_count++;
  54. }
  55. void RemoveAt(int i, VERTEX& v)
  56. {
  57. GetAt(i, v);
  58. i = (m_head+i)&3;
  59. if(i == m_head) m_head = (m_head+1)&3;
  60. else for(m_tail = (m_tail+4-1)&3; i != m_tail; i = (i+1)&3) m_v[i] = m_v[(i+1)&3];
  61. m_count--;
  62. }
  63. void GetAt(int i, VERTEX& v)
  64. {
  65. ASSERT(m_count > 0); 
  66. v = m_v[(m_head+i)&3];
  67. }
  68. int GetCount()
  69. {
  70. return m_count;
  71. }
  72. };