Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(256)

Side by Side Diff: core/cross/command_buffer/texture_cb.h

Issue 234002: More work in Command Buffers... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/o3d/
Patch Set: Created 11 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « core/cross/command_buffer/stream_bank_cb.cc ('k') | core/cross/command_buffer/texture_cb.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2009, Google Inc. 2 * Copyright 2009, Google Inc.
3 * All rights reserved. 3 * All rights reserved.
4 * 4 *
5 * Redistribution and use in source and binary forms, with or without 5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are 6 * modification, are permitted provided that the following conditions are
7 * met: 7 * met:
8 * 8 *
9 * * Redistributions of source code must retain the above copyright 9 * * Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer. 10 * notice, this list of conditions and the following disclaimer.
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
74 unsigned height, 74 unsigned height,
75 const void* src_data, 75 const void* src_data,
76 int src_pitch); 76 int src_pitch);
77 77
78 // Returns the implementation-specific texture handle for this texture. 78 // Returns the implementation-specific texture handle for this texture.
79 virtual void* GetTextureHandle() const { 79 virtual void* GetTextureHandle() const {
80 return reinterpret_cast<void*>(resource_id_); 80 return reinterpret_cast<void*>(resource_id_);
81 } 81 }
82 82
83 // Gets the texture resource ID. 83 // Gets the texture resource ID.
84 command_buffer::ResourceID resource_id() const { return resource_id_; } 84 command_buffer::ResourceId resource_id() const { return resource_id_; }
85 85
86 // Gets a RGBASwizzleIndices that contains a mapping from 86 // Gets a RGBASwizzleIndices that contains a mapping from
87 // RGBA to the internal format used by the rendering API. 87 // RGBA to the internal format used by the rendering API.
88 virtual const RGBASwizzleIndices& GetABGR32FSwizzleIndices(); 88 virtual const RGBASwizzleIndices& GetABGR32FSwizzleIndices();
89 89
90 protected: 90 protected:
91 // Overridden from Texture2D 91 // Overridden from Texture2D
92 virtual bool PlatformSpecificLock( 92 virtual bool PlatformSpecificLock(
93 int level, void** texture_data, int* pitch, AccessMode mode); 93 int level, void** texture_data, int* pitch, AccessMode mode);
94 94
95 // Overridden from Texture2D 95 // Overridden from Texture2D
96 virtual bool PlatformSpecificUnlock(int level); 96 virtual bool PlatformSpecificUnlock(int level);
97 97
98 // Overridden from Texture2D 98 // Overridden from Texture2D
99 virtual RenderSurface::Ref PlatformSpecificGetRenderSurface(int mip_level); 99 virtual RenderSurface::Ref PlatformSpecificGetRenderSurface(int mip_level);
100 100
101 private: 101 private:
102 // Initializes the Texture2DCB from a preexisting OpenCB texture handle 102 // Initializes the Texture2DCB from a preexisting OpenCB texture handle
103 // and raw Bitmap data. 103 // and raw Bitmap data.
104 // The texture takes ownership of the bitmap data. 104 // The texture takes ownership of the bitmap data.
105 Texture2DCB(ServiceLocator* service_locator, 105 Texture2DCB(ServiceLocator* service_locator,
106 command_buffer::ResourceID resource_id, 106 command_buffer::ResourceId resource_id,
107 Texture::Format format, 107 Texture::Format format,
108 int levels, 108 int levels,
109 int width, 109 int width,
110 int height, 110 int height,
111 bool enable_render_surfaces); 111 bool enable_render_surfaces);
112 112
113 // Returns true if the backing bitmap has the data for the level. 113 // Returns true if the backing bitmap has the data for the level.
114 bool HasLevel(unsigned int level) { 114 bool HasLevel(unsigned int level) {
115 DCHECK_LT(level, static_cast<unsigned int>(levels())); 115 DCHECK_LT(level, static_cast<unsigned int>(levels()));
116 return (has_levels_ & (1 << level)) != 0; 116 return (has_levels_ & (1 << level)) != 0;
117 } 117 }
118 118
119 RendererCB* renderer_; 119 RendererCB* renderer_;
120 command_buffer::ResourceID resource_id_; 120 command_buffer::ResourceId resource_id_;
121 121
122 // A bitmap used to back the NPOT textures on POT-only hardware, and to back 122 // A bitmap used to back the NPOT textures on POT-only hardware, and to back
123 // the pixel buffer for Lock(). 123 // the pixel buffer for Lock().
124 Bitmap::Ref backing_bitmap_; 124 Bitmap::Ref backing_bitmap_;
125 125
126 // Bitfield that indicates mip levels that are currently stored in the 126 // Bitfield that indicates mip levels that are currently stored in the
127 // backing bitmap. 127 // backing bitmap.
128 unsigned int has_levels_; 128 unsigned int has_levels_;
129 129
130 // Bitfield that indicates which mip levels are currently locked. 130 // Bitfield that indicates which mip levels are currently locked.
(...skipping 24 matching lines...) Expand all
155 unsigned height, 155 unsigned height,
156 const void* src_data, 156 const void* src_data,
157 int src_pitch); 157 int src_pitch);
158 158
159 // Returns the implementation-specific texture handle for this texture. 159 // Returns the implementation-specific texture handle for this texture.
160 virtual void* GetTextureHandle() const { 160 virtual void* GetTextureHandle() const {
161 return reinterpret_cast<void*>(resource_id_); 161 return reinterpret_cast<void*>(resource_id_);
162 } 162 }
163 163
164 // Gets the texture resource ID. 164 // Gets the texture resource ID.
165 command_buffer::ResourceID resource_id() const { return resource_id_; } 165 command_buffer::ResourceId resource_id() const { return resource_id_; }
166 166
167 // Gets a RGBASwizzleIndices that contains a mapping from 167 // Gets a RGBASwizzleIndices that contains a mapping from
168 // RGBA to the internal format used by the rendering API. 168 // RGBA to the internal format used by the rendering API.
169 virtual const RGBASwizzleIndices& GetABGR32FSwizzleIndices(); 169 virtual const RGBASwizzleIndices& GetABGR32FSwizzleIndices();
170 170
171 protected: 171 protected:
172 // Overridden from TextureCUBE 172 // Overridden from TextureCUBE
173 virtual bool PlatformSpecificLock( 173 virtual bool PlatformSpecificLock(
174 CubeFace face, int level, void** texture_data, int* pitch, 174 CubeFace face, int level, void** texture_data, int* pitch,
175 AccessMode mode); 175 AccessMode mode);
176 176
177 // Overridden from TextureCUBE 177 // Overridden from TextureCUBE
178 virtual bool PlatformSpecificUnlock(CubeFace face, int level); 178 virtual bool PlatformSpecificUnlock(CubeFace face, int level);
179 179
180 // Overridden from TextureCUBE. 180 // Overridden from TextureCUBE.
181 virtual RenderSurface::Ref PlatformSpecificGetRenderSurface(CubeFace face, 181 virtual RenderSurface::Ref PlatformSpecificGetRenderSurface(CubeFace face,
182 int level); 182 int level);
183 private: 183 private:
184 // Creates a texture from a pre-existing texture resource. 184 // Creates a texture from a pre-existing texture resource.
185 TextureCUBECB(ServiceLocator* service_locator, 185 TextureCUBECB(ServiceLocator* service_locator,
186 command_buffer::ResourceID texture, 186 command_buffer::ResourceId texture,
187 Texture::Format format, 187 Texture::Format format,
188 int levels, 188 int levels,
189 int edge_length, 189 int edge_length,
190 bool enable_render_surfaces); 190 bool enable_render_surfaces);
191 191
192 192
193 // Returns true if the backing bitmap has the data for the level. 193 // Returns true if the backing bitmap has the data for the level.
194 bool HasLevel(CubeFace face, unsigned int level) { 194 bool HasLevel(CubeFace face, unsigned int level) {
195 DCHECK_LT(level, static_cast<unsigned int>(levels())); 195 DCHECK_LT(level, static_cast<unsigned int>(levels()));
196 return (has_levels_[face] & (1 << level)) != 0; 196 return (has_levels_[face] & (1 << level)) != 0;
197 } 197 }
198 198
199 RendererCB* renderer_; 199 RendererCB* renderer_;
200 command_buffer::ResourceID resource_id_; 200 command_buffer::ResourceId resource_id_;
201 201
202 // Bitmaps used to back the NPOT textures on POT-only hardware. 202 // Bitmaps used to back the NPOT textures on POT-only hardware.
203 Bitmap::Ref backing_bitmaps_[NUMBER_OF_FACES]; 203 Bitmap::Ref backing_bitmaps_[NUMBER_OF_FACES];
204 204
205 // Bitfields that indicates mip levels that are currently stored in the 205 // Bitfields that indicates mip levels that are currently stored in the
206 // backing bitmap, one per face. 206 // backing bitmap, one per face.
207 unsigned int has_levels_[NUMBER_OF_FACES]; 207 unsigned int has_levels_[NUMBER_OF_FACES];
208 208
209 // Bitfields that indicates which levels are currently locked, one per face. 209 // Bitfields that indicates which levels are currently locked, one per face.
210 unsigned int locked_levels_[NUMBER_OF_FACES]; 210 unsigned int locked_levels_[NUMBER_OF_FACES];
211 }; 211 };
212 212
213 } // namespace o3d 213 } // namespace o3d
214 214
215 #endif // O3D_CORE_CROSS_COMMAND_BUFFER_TEXTURE_CB_H_ 215 #endif // O3D_CORE_CROSS_COMMAND_BUFFER_TEXTURE_CB_H_
OLDNEW
« no previous file with comments | « core/cross/command_buffer/stream_bank_cb.cc ('k') | core/cross/command_buffer/texture_cb.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698