Cocos2d-x   发布时间:2022-05-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了在cocos2dx 中添加自定义 shaders --- 改变 HSL 色调,饱和度, 亮度大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

步骤1

准备shaders文件-ccShad_Hsl.h

@H_772_24@/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (C) 2011 Brian Chapados
* Permission is hereby granted,free of charge,to any person obtaining a copy
* of this software and associated documentation files (the "Software"),to deal
* in the Software without reStriction,including without limitation the rights
* to use,copy,modify,merge,publish,diStribute,sublicense,and/or sell
* copies of the Software,and to permit persons to whom the Software is
* furnished to do so,subject to the following conditions:
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
* THE SOFTWARE IS PROVIDED "AS IS",WITHOUT WARRANTY OF ANY KIND,EXPRESS OR
* IMPLIED,INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITnesS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,DAMAGES OR OTHER
* LIABILITY,WHETHER IN AN ACTION OF CONTRACT,TORT OR OTHERWISE,ARISING FROM,0)"> * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/

" \n\
#ifdef GL_ES \n\
precision mediump float; \n\
#endif \n\
\n\
varying vec2 v_texCoord; \n\
uniform sampler2D CC_Texture0; \n\
\n\
uniform float AddHue; \n\
uniform float AddSat; \n\
uniform float AddLig; \n\
uniform float AddRed; \n\
uniform float AddGreen; \n\
uniform float AddBlue; \n\
uniform float AddAlpha; \n\
float Hue_2_RGB(float v1,float v2,float vH ) \n\
{ \n\
float ret;\n\
if ( vH < 0.0 )\n\
vH += 1.0;\n\
if ( vH > 1.0 )\n\
vH -= 1.0;\n\
if ( ( 6.0 * vH ) < 1.0 )\n\
ret = ( v1 + ( v2 - v1 ) * 6.0 * vH );\n\
else if ( ( 2.0 * vH ) < 1.0 )\n\
ret = ( v2 );\n\
else if ( ( 3.0 * vH ) < 2.0 )\n\
ret = ( v1 + ( v2 - v1 ) * ( ( 2.0 / 3.0 ) - vH ) * 6.0 );\n\
else\n\
ret = v1;\n\
return ret;\n\
}\n\
void main(void)\n\
{\n\
float Cmax,Cmin;\n\
float D;\n\
float H,S,L;\n\
float R,G,B;\n\
vec4 color = texture2D(CC_Texture0,v_texCoord);\n\
R = color.r;\n\
G = color.g;\n\
B = color.b;\n\
Cmax = max (R,max (G,B));\n\
Cmin = min (R,min (G,0)"> L = (Cmax + Cmin) / 2.0;\n\
if (Cmax == Cmin)\n\
{\n\
H = 0.0;\n\
S = 0.0;\n\
}\n\
D = Cmax - Cmin;\n\
if (L < 0.5)\n\
S = D / (Cmax + Cmin);\n\
S = D / (2.0 - (Cmax + Cmin));\n\
if (R == CmaX)\n\
H = (G - B) / D;\n\
} else {\n\
if (G == CmaX)\n\
H = 2.0 + (B - R) /D;\n\
H = 4.0 + (R - G) / D;\n\
H = H / 6.0;\n\
// modify H/S/L values\n\
H += AddHue;\n\
S += AddSat;\n\
L += AddLig;\n\
if (H < 0.0)\n\
H = H + 1.0;\n\
H = clamp(H,0.0,1.0);\n\
S = clamp(S,0)"> L = clamp(L,0)"> // convert BACk to RGB\n\
float var_2,var_1;\n\
if (S == 0.0)\n\
R = L;\n\
G = L;\n\
B = L;\n\
if ( L < 0.5 )\n\
var_2 = L * ( 1.0 + S );\n\
var_2 = ( L + S ) - ( S * L );\n\
var_1 = 2.0 * L - var_2;\n\
R = Hue_2_RGB( var_1,var_2,H + ( 1.0 / 3.0 ) );\n\
G = Hue_2_RGB( var_1,H );\n\
B = Hue_2_RGB( var_1,H - ( 1.0 / 3.0 ) );\n\
R = R * AddRed;\n\
G = G * AddGreen;\n\
B = B * AddBlue;\n\
gl_FragColor = vec4(R,B,color.a * AddAlpha);\n\
";


将它放入E:\HSluZiLong\cocos2d-x-2.2.1\cocos2d-x-2.2.1\cocos2dx\shaders 目录下

步骤2.

在ccShaders.h 中加入代码

extern CC_DLL const GLchar * ccPositionColorHSL_frag;
extern CC_DLL const GLchar * ccPositionColorHSL_vert;

在ccShaders.cpp 中加入代码

const GLchar * ccPositionColorHSL_frag =
#include "ccShad_Hsl.h"


在CCGLProgram.h 中定义

#define KCCShader_Position_hsl"KCCShader_Position_hsl"

在CCShaderCache.cpp 中 追加枚举kCCShaderType_Position_hsl,

在CCShaderCache.cpp 的reloadDefaultShaders中加入代码

p = programForKey(KCCShader_Position_hsl);
p->reset();
loadDefaultShader(p,kCCShaderType_Position_hsl);

在CCShaderCache.cpp 的loadDefaultShader中加入代码

case kCCShaderType_Position_hsl:
p->initWithVertexShaderByteArray(ccPositiontextureColor_vert,ccPositionColorHSL_frag);
p->addAttribute(kCCAttributenamePosition,kCCVertexAttrib_Position);
p->addAttribute(kCCAttributenameColor,kCCVertexAttrib_Color);
p->addAttribute(kCCAttributenameTexCoord,kCCVertexAttrib_TexCoords);
break;

在CCShaderCache.cpp 的loadDefaultShaders中加入代码

p = new CCGLProgram();
loadDefaultShader(p,kCCShaderType_Position_hsl);

m_pPrograms->setObject(p,KCCShader_Position_hsl);
p->release();

步骤3.

在CCSprite 类中 追加 HSL 接口

@H_772_24@ bool m_use_hsl;
GLfloat m_color_h m_color_s m_color_l m_color_aGLuint hLOCATIOn sLOCATIOn lLOCATIOn rLOCATIOn gLOCATIOn bLOCATIOn aLOCATIOn;



  1. voidinitHSL();
  2. voiddrawHSL();
  3. voidsetHSL(floath,floats,87); BACkground-color:inherit">floatl);
  4. voidsetH(floath);
  5. voidsetS(floats);
  6. voidsetL( floatgetH(void){return@H_292_481@m_color_h;}
  7. floatgetS(return@H_292_481@m_color_s;}
  8. floatgetL(return@H_292_481@m_color_l;}
@H_304_@R_262_11235@@copy
    voidCCSprite::initHSL()
  1. {
  2. if(m_use_hsl==false)
  3. @H_269_476@m_use_hsl=true;
  4. setShaderProgram(CCShaderCache::sharedShaderCache()->programForKey(KCCShader_Position_hsl));
  5. hLOCATIOn=glGetUniformLOCATIOn(getShaderProgram()->getProgram(),"AddHue");
  6. sLOCATIOn=glGetUniformLOCATIOn(getShaderProgram()->getProgram(),"AddSat");
  7. lLOCATIOn=glGetUniformLOCATIOn(getShaderProgram()->getProgram(),"AddLig");
  8. rLOCATIOn=glGetUniformLOCATIOn(getShaderProgram()->getProgram(),"AddRed");
  9. gLOCATIOn=glGetUniformLOCATIOn(getShaderProgram()->getProgram(),"AddGreen");
  10. bLOCATIOn=glGetUniformLOCATIOn(getShaderProgram()->getProgram(),"AddBlue");
  11. aLOCATIOn=glGetUniformLOCATIOn(getShaderProgram()->getProgram(),"AddAlpha");
  12. }
  13. }
  14. voidCCSprite::drawHSL()
  15. {
  16. ccBlendFuncblend=getBlendFunc();
  17. ccGLBlendFunc(blend.src,blend.dst);
  18. getShaderProgram()->use();
  19. getShaderProgram()->setUniformsForBuilTins();
  20. getShaderProgram()->setUniformLOCATIOnWith1f(hLOCATIOn,m_color_h);
  21. getShaderProgram()->setUniformLOCATIOnWith1f(sLOCATIOn,m_color_s);
  22. getShaderProgram()->setUniformLOCATIOnWith1f(lLOCATIOn,m_color_l);
  23. getShaderProgram()->setUniformLOCATIOnWith1f(rLOCATIOn,_displayedColor.r/255.f);
  24. getShaderProgram()->setUniformLOCATIOnWith1f(gLOCATIOn,_displayedColor.g/255.f);
  25. getShaderProgram()->setUniformLOCATIOnWith1f(bLOCATIOn,_displayedColor.b/255.f);
  26. @H_269_476@m_color_a=this->getOpacity()/255.f;
  27. getShaderProgram()->setUniformLOCATIOnWith1f(aLOCATIOn,m_color_a);
  28. ccGLBindTexture2D(getTexture()->getName());
  29. ccGLEnableVertexAttribs(kCCVertexAttribFlag_PosColorTeX);
  30. @H_666_801@#definekQuadSizesizeof(m_sQuad.bl)
  31. longoffset=(long)&m_sQuad;
  32. //vertex
  33. intdiff=offsetof(ccV3F_C4B_T2F,vertices);
  34. glVertexAttribPointer(kCCVertexAttrib_Position,3,GL_FLOAT,GL_falSE,kQuadSize,(void*)(offset+diff));
  35. //texCoods
  36. diff=offsetof(ccV3F_C4B_T2F,texCoords);
  37. glVertexAttribPointer(kCCVertexAttrib_TexCoords,2,0); BACkground-color:inherit">//color
  38. :17.6000003814697px; border-style:none none none solid; border-left-width:3px; border-left-color:rgb(108,colors);
  39. glVertexAttribPointer(kCCVertexAttrib_Color,4,GL_UNSIGNED_BYTE,GL_TRUE,248)"> glDrawArrays(GL_TRIANGLE_StriP,4);
  40. CC_INCREMENT_GL_DRAWS(1);
  41. voidCCSprite::setHSL(floatl)
  42. initHSL();
  43. setH(h);
  44. setS(s);
  45. setL(l);
  46. voidCCSprite::setH(floath)
  47. initHSL();
  48. @H_269_476@m_color_h=h;
  49. voidCCSprite::setS(floats)
  50. @H_269_476@m_color_s=s;
  51. voidCCSprite::setL( @H_269_476@m_color_l=l;
  52. if(m_color_l>0)
  53. blend.src=GL_SRC_ALPHA;
  54. else
  55. blend.src=GL_ONE;
  56. blend.dst=GL_ONE_MINUS_SRC_ALPHA;
  57. setBlendFunc(blend);
  58. }

在CCSprite.cpp 的updateBlendFunc中追加代码

if(m_use_hsl)
{
ccBlendFunc blend = getBlendFunc();
if(m_color_l > 0)
blend.src = GL_SRC_ALPHA;
else
blend.src = GL_ONE;
blend.dst = GL_ONE_MINUS_SRC_ALPHA;
setBlendFunc(blend);
}

在CCSprite.cpp 的setTexture中追加代码

if(this->m_use_hsl)
{
@H_167_6@m_use_hsl = false;
initHSL();
}


在CCSprite.cpp 的draw 开头插入代码

if(m_use_hsl)
{
drawHSL();
return;
}

步骤5.

调用接口

copy
    CCSprite*pSprite=CCSprite::create("Icon.png");
  1. //-1~10无变化
  2. pSprite->setS(-1);
  3. //positionthespriteonthecenterofthescreen
  4. pSprite->setPosition(ccp(visibleSize.width/2+origin.x,visibleSize.height/2+origin.y));
  5. //addthespriteasachildtothislayer
  6. this->addChild(pSprite,0);
  7. }


|字号订阅

大佬总结

以上是大佬教程为你收集整理的在cocos2dx 中添加自定义 shaders --- 改变 HSL 色调,饱和度, 亮度全部内容,希望文章能够帮你解决在cocos2dx 中添加自定义 shaders --- 改变 HSL 色调,饱和度, 亮度所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:cocoscocos2dxdxhslshaders亮度改变添加自定义色调饱和度
猜你在找的Cocos2d-x相关文章
其他相关热搜词更多
phpJavaPython程序员load如何string使用参数jquery开发安装listlinuxiosandroid工具javascriptcap