diff options
author | Jason Sams <rjsams@android.com> | 2010-08-04 17:50:20 -0700 |
---|---|---|
committer | Jason Sams <rjsams@android.com> | 2010-08-05 10:00:21 -0700 |
commit | 442a647424e6537e94341654e3ae5d52efd84862 (patch) | |
tree | 0a73c7551dceac6b4a81ee6ddb9b7f2ef11c89b4 /libs/rs/rsScriptC_LibGL.cpp | |
parent | 208c425e842afed177801016c00c2c01bd8b44aa (diff) |
Support constant and varying colors in ProgramFragment.
Change-Id: I16ce84ff427016f3a1923594efc718eca32dd7f2
Diffstat (limited to 'libs/rs/rsScriptC_LibGL.cpp')
-rw-r--r-- | libs/rs/rsScriptC_LibGL.cpp | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/libs/rs/rsScriptC_LibGL.cpp b/libs/rs/rsScriptC_LibGL.cpp index 22b0945be04a..f5e595340aff 100644 --- a/libs/rs/rsScriptC_LibGL.cpp +++ b/libs/rs/rsScriptC_LibGL.cpp @@ -110,6 +110,13 @@ static void SC_vpLoadTextureMatrix(const rsc_Matrix *m) } +static void SC_pfConstantColor(RsProgramFragment vpf, float r, float g, float b, float a) +{ + //GET_TLS(); + ProgramFragment *pf = static_cast<ProgramFragment *>(vpf); + pf->setConstantColor(r, g, b, a); +} + ////////////////////////////////////////////////////////////////////////////// // Drawing @@ -253,13 +260,8 @@ static void SC_drawMeshPrimitiveRange(RsMesh vsm, uint32_t primIndex, uint32_t s static void SC_color(float r, float g, float b, float a) { GET_TLS(); - rsc->mStateVertex.color[0] = r; - rsc->mStateVertex.color[1] = g; - rsc->mStateVertex.color[2] = b; - rsc->mStateVertex.color[3] = a; - if (!rsc->checkVersion2_0()) { - glColor4f(r, g, b, a); - } + ProgramFragment *pf = (ProgramFragment *)rsc->getFragment(); + pf->setConstantColor(r, g, b, a); } static void SC_uploadToTexture2(RsAllocation va, uint32_t baseMipLevel) @@ -371,6 +373,8 @@ static ScriptCState::SymbolTable_t gSyms[] = { { "_Z31rsgProgramVertexLoadModelMatrixPK12rs_matrix4x4", (void *)&SC_vpLoadModelMatrix }, { "_Z33rsgProgramVertexLoadTextureMatrixPK12rs_matrix4x4", (void *)&SC_vpLoadTextureMatrix }, + { "_Z31rsgProgramFragmentConstantColor19rs_program_fragmentffff", (void *)&SC_pfConstantColor }, + { "_Z11rsgGetWidthv", (void *)&SC_getWidth }, { "_Z12rsgGetHeightv", (void *)&SC_getHeight }, |