OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2011 Google Inc. | 2 * Copyright 2011 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #ifndef GrGpu_DEFINED | 8 #ifndef GrGpu_DEFINED |
9 #define GrGpu_DEFINED | 9 #define GrGpu_DEFINED |
10 | 10 |
(...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
79 * @param desc describes the texture to be created. | 79 * @param desc describes the texture to be created. |
80 * @param srcData texel data to load texture. Begins with full-size | 80 * @param srcData texel data to load texture. Begins with full-size |
81 * palette data for paletted textures. Contains width* | 81 * palette data for paletted textures. Contains width* |
82 * height texels. If NULL texture data is uninitialized. | 82 * height texels. If NULL texture data is uninitialized. |
83 * | 83 * |
84 * @return The texture object if successful, otherwise NULL. | 84 * @return The texture object if successful, otherwise NULL. |
85 */ | 85 */ |
86 GrTexture* createTexture(const GrTextureDesc& desc, | 86 GrTexture* createTexture(const GrTextureDesc& desc, |
87 const void* srcData, size_t rowBytes); | 87 const void* srcData, size_t rowBytes); |
88 | 88 |
89 /** | 89 /** |
robertphillips
2014/05/30 15:00:22
Can we test these cases (on a Xoom say) ?
| |
90 * Creates a compressed texture object. If desc width or height is not a pow er of | |
91 * two but underlying API requires a power of two texture then this function will | |
92 * return NULL. If the pixel configuration passed in desc is not a valid for mat | |
93 * supported by the device, then this function will return NULL. | |
94 * | |
95 * The kRenderTarget_TextureFlag should not be specified | |
96 * | |
97 * @param desc describes the texture to be created. The width and hei ght of | |
98 * the texture should be multiples of the block size for the | |
99 * requested compressed format. The origin of the texture is | |
100 * also expected to be in the top left. | |
101 * @param srcData texel data to load texture. This is expected to be the | |
102 * proper size based on the width and height of the textu re along | |
103 * with the associated block size specified in GrTextureF ormatDesc | |
104 * | |
105 * @return The texture object if successful, otherwise NULL. | |
106 */ | |
107 GrTexture* createCompressedTexture(const GrTextureDesc& desc, const void* sr cData); | |
bsalomon
2014/05/30 15:16:58
I'm wondering if this makes sense as a public GrGp
krajcevski
2014/05/30 16:21:50
I agree to an extent... it's always better to be i
| |
108 | |
109 /** | |
90 * Implements GrContext::wrapBackendTexture | 110 * Implements GrContext::wrapBackendTexture |
91 */ | 111 */ |
92 GrTexture* wrapBackendTexture(const GrBackendTextureDesc&); | 112 GrTexture* wrapBackendTexture(const GrBackendTextureDesc&); |
93 | 113 |
94 /** | 114 /** |
95 * Implements GrContext::wrapBackendTexture | 115 * Implements GrContext::wrapBackendTexture |
96 */ | 116 */ |
97 GrRenderTarget* wrapBackendRenderTarget(const GrBackendRenderTargetDesc&); | 117 GrRenderTarget* wrapBackendRenderTarget(const GrBackendRenderTargetDesc&); |
98 | 118 |
99 /** | 119 /** |
(...skipping 307 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
407 | 427 |
408 | 428 |
409 // called when the 3D context state is unknown. Subclass should emit any | 429 // called when the 3D context state is unknown. Subclass should emit any |
410 // assumed 3D context state and dirty any state cache. | 430 // assumed 3D context state and dirty any state cache. |
411 virtual void onResetContext(uint32_t resetBits) = 0; | 431 virtual void onResetContext(uint32_t resetBits) = 0; |
412 | 432 |
413 // overridden by backend-specific derived class to create objects. | 433 // overridden by backend-specific derived class to create objects. |
414 virtual GrTexture* onCreateTexture(const GrTextureDesc& desc, | 434 virtual GrTexture* onCreateTexture(const GrTextureDesc& desc, |
415 const void* srcData, | 435 const void* srcData, |
416 size_t rowBytes) = 0; | 436 size_t rowBytes) = 0; |
437 virtual GrTexture* onCreateCompressedTexture(const GrTextureDesc& desc, | |
438 const void* srcData) = 0; | |
417 virtual GrTexture* onWrapBackendTexture(const GrBackendTextureDesc&) = 0; | 439 virtual GrTexture* onWrapBackendTexture(const GrBackendTextureDesc&) = 0; |
418 virtual GrRenderTarget* onWrapBackendRenderTarget(const GrBackendRenderTarge tDesc&) = 0; | 440 virtual GrRenderTarget* onWrapBackendRenderTarget(const GrBackendRenderTarge tDesc&) = 0; |
419 virtual GrVertexBuffer* onCreateVertexBuffer(size_t size, bool dynamic) = 0; | 441 virtual GrVertexBuffer* onCreateVertexBuffer(size_t size, bool dynamic) = 0; |
420 virtual GrIndexBuffer* onCreateIndexBuffer(size_t size, bool dynamic) = 0; | 442 virtual GrIndexBuffer* onCreateIndexBuffer(size_t size, bool dynamic) = 0; |
421 virtual GrPath* onCreatePath(const SkPath& path, const SkStrokeRec&) = 0; | 443 virtual GrPath* onCreatePath(const SkPath& path, const SkStrokeRec&) = 0; |
422 | 444 |
423 // overridden by backend-specific derived class to perform the clear and | 445 // overridden by backend-specific derived class to perform the clear and |
424 // clearRect. NULL rect means clear whole target. If canIgnoreRect is | 446 // clearRect. NULL rect means clear whole target. If canIgnoreRect is |
425 // true, it is okay to perform a full clear instead of a partial clear | 447 // true, it is okay to perform a full clear instead of a partial clear |
426 virtual void onClear(const SkIRect* rect, GrColor color, bool canIgnoreRect) = 0; | 448 virtual void onClear(const SkIRect* rect, GrColor color, bool canIgnoreRect) = 0; |
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
514 // these are mutable so they can be created on-demand | 536 // these are mutable so they can be created on-demand |
515 mutable GrIndexBuffer* fQuadInd exBuffer; | 537 mutable GrIndexBuffer* fQuadInd exBuffer; |
516 // Used to abandon/release all resources created by this GrGpu. TODO: Move t his | 538 // Used to abandon/release all resources created by this GrGpu. TODO: Move t his |
517 // functionality to GrResourceCache. | 539 // functionality to GrResourceCache. |
518 ObjectList fObjectL ist; | 540 ObjectList fObjectL ist; |
519 | 541 |
520 typedef GrDrawTarget INHERITED; | 542 typedef GrDrawTarget INHERITED; |
521 }; | 543 }; |
522 | 544 |
523 #endif | 545 #endif |
OLD | NEW |