cocos2dx3.X shader使图片置灰

1 OpenGL ES着色器

opengl es的着色器有.fsh和.vsh两个文件。这两个文件在被编译和链接后就可以产生可执行程序与GPU交互。attribute是从外部传进来的,每一个顶点都会有这两个属性,所以它也叫做vertex attribute(顶点属性)。而varying类型的变量是在vertex shader和fragment shader之间传递数据用的。

.vsh 是 vertex shader,用与顶点计算,可以理解控制顶点的位置,在这个文件中我们通常会传入当前顶点的位置,和纹理的坐标。新建gray.vsh文件。

attribute vec4 a_position;
attribute vec2 a_texCoord;
attribute vec4 a_color;
					
varying vec4 v_fragmentColor;
varying vec2 v_texCoord;
								
void main()	
{							
    gl_Position = CC_PMatrix * a_position;
	v_fragmentColor = a_color;
	v_texCoord = a_texCoord;
}

gray.fsh 是片段shader。在这里面我可以对于每一个像素点进行重新计算。

varying vec4 v_fragmentColor;	
varying vec2 v_texCoord;	
		
void main()			
{
	vec4 v_orColor = v_fragmentColor * texture2D(CC_Texture0, v_texCoord);
	float gray = dot(v_orColor.rgb, vec3(0.299, 0.587, 0.114));
	gl_FragColor = vec4(gray, gray, gray, v_orColor.a);
}		

两个文件放在resource文件夹下。

2 使图片置灰

void HelloWorld::sprAddGray(Sprite * sprite)
{
	if (sprite)
	{
		GLProgram * p = new GLProgram();
		p->initWithFilenames("gray.vsh", "gray.fsh");
		p->bindAttribLocation(GLProgram::ATTRIBUTE_NAME_POSITION, GLProgram::VERTEX_ATTRIB_POSITION);
		p->bindAttribLocation(GLProgram::ATTRIBUTE_NAME_COLOR, GLProgram::VERTEX_ATTRIB_COLOR);
		p->bindAttribLocation(GLProgram::ATTRIBUTE_NAME_TEX_COORD, GLProgram::VERTEX_ATTRIB_TEX_COORDS);
		p->link();
		p->updateUniforms();
		sprite->setShaderProgram(p);
	}
}

3 使图片还原

void HelloWorld::sprRemoveGray(CCSprite * sprite)
{
	if (sprite !=NULL)
	{
		std::string str = "ShaderPositionTextureColor_noMVP";
		CCGLProgram * pProgram = CCShaderCache::sharedShaderCache()->programForKey(str);
		sprite ->setShaderProgram(pProgram);
		CHECK_GL_ERROR_DEBUG();
	} 
}

4 运行效果

程序中响应按钮代码如下,形成灰色与彩色图交替显示。

void HelloWorld::onBtnColorChange(Ref* MyRef)
{
	static int idx = 0;
	if (idx % 2 == 0)
	{
		sprAddGray(m_spr);
	}
	else
	{
		sprRemoveGray(m_spr);
	}
	idx++;
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,我可以为您提供一个基于 cocoscreator 2.4.x 的发光 shader。以下是代码: ``` CCEffect %{ techniques: - name: glow passes: - vert: ccShader_PositionTextureColor_vert frag: glow_frag } %} CCProgram glow { CCShader_PositionTextureColor_vert, highp vec4 blurSize; void main() { mat4 mvp; CC_USE_MVP(mvp); gl_Position = mvp * vec4(a_position, 1); v_fragmentColor = a_color; v_texCoord = a_texCoord; } CCShader_Header { uniform highp vec4 blurSize; varying lowp vec4 v_fragmentColor; varying mediump vec2 v_texCoord; const highp float glowPow = 2.0; const highp float glowStrength = 0.5; } CCShader glow_frag { highp vec4 blurSize; highp float blurRadius = 2.0; void main() { highp vec4 sum = vec4(0.0); highp vec2 texcoord = v_texCoord.xy; highp vec2 blur = blurSize.xy; highp float strength = blurSize.z; highp float glow = blurSize.w; highp float samples = 8.0; highp vec4 col = texture2D(CC_Texture0, texcoord); for (highp float i = 0.0; i < samples; i++) { highp float angle = i / samples * 3.14159265 * 2.0; highp vec2 blurDirection = vec2(sin(angle), cos(angle)); highp vec4 blurCol = texture2D(CC_Texture0, texcoord + blurDirection * blurRadius * blur); sum += blurCol; } highp vec4 glowCol = sum / samples; glowCol = (glowCol - col) * glow * glowPow + col; gl_FragColor = mix(col, glowCol, strength) * v_fragmentColor; } } } ``` 您可以将此代码添加到您的 cocoscreator 2.4.x 项目中,然后将此 shader 应用于需要发光效果的 sprite 上。希望这可以帮到您!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

四夕立羽

你的鼓励将是我创作的最大动力。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值