位置: 编程技术 - 正文

在cocos2dx 中添加自定义 shaders --- 改变 HSL 色调,饱和度, 亮度(cocos怎么用)

编辑:rootadmin

推荐整理分享在cocos2dx 中添加自定义 shaders --- 改变 HSL 色调,饱和度, 亮度(cocos怎么用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:cocos2dx怎么用,cocos2dx创建项目,cocos2d教程,cocos2dx创建项目,cocos怎么用,cocos2d怎么创建项目,cocos2dx怎么用,cocos2dx怎么用,内容如对您有帮助,希望把文章链接给更多的朋友!

订阅

步骤1

准备 shaders文件- ccShad_Hsl.h

将它放入E:HSluZiLongcocos2d-x-2.2.1cocos2d-x-2.2.1cocos2dxshaders 目录下

步骤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 接口

[cpp] view plaincopyvoid initHSL(); void drawHSL(); void setHSL(float h, float s, float l); void setH(float h); void setS(float s); void setL(float l); float getH(void){ return m_color_h;} float getS(void){ return m_color_s;} float getL(void){ return m_color_l;} [cpp] view plaincopyvoid CCSprite::initHSL() { if(m_use_hsl == false) { m_use_hsl = true; setShaderProgram(CCShaderCache::sharedShaderCache()->programForKey(KCCShader_Position_hsl)); hLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddHue"); sLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddSat"); lLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddLig"); rLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddRed"); gLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddGreen"); bLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddBlue"); aLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddAlpha"); } } void CCSprite::drawHSL() { ccBlendFunc blend = getBlendFunc(); ccGLBlendFunc(blend.src, blend.dst); getShaderProgram()->use(); getShaderProgram()->setUniformsForBuiltins(); getShaderProgram()->setUniformLocationWith1f(hLocation, m_color_h); getShaderProgram()->setUniformLocationWith1f(sLocation, m_color_s); getShaderProgram()->setUniformLocationWith1f(lLocation, m_color_l); getShaderProgram()->setUniformLocationWith1f(rLocation, _displayedColor.r/.f); getShaderProgram()->setUniformLocationWith1f(gLocation, _displayedColor.g/.f); getShaderProgram()->setUniformLocationWith1f(bLocation, _displayedColor.b/.f); m_color_a = this->getOpacity() / .f; getShaderProgram()->setUniformLocationWith1f(aLocation, m_color_a); ccGLBindTexture2D( getTexture()->getName()); ccGLEnableVertexAttribs(kCCVertexAttribFlag_PosColorTex ); #define kQuadSize sizeof(m_sQuad.bl) long offset = (long)&m_sQuad; // vertex int diff = offsetof( ccV3F_C4B_T2F, vertices); glVertexAttribPointer(kCCVertexAttrib_Position, 3, GL_FLOAT, GL_FALSE, kQuadSize, (void*) (offset &#; diff)); // texCoods diff = offsetof( ccV3F_C4B_T2F, texCoords); glVertexAttribPointer(kCCVertexAttrib_TexCoords, 2, GL_FLOAT, GL_FALSE, kQuadSize, (void*)(offset &#; diff)); // color diff = offsetof( ccV3F_C4B_T2F, colors); glVertexAttribPointer(kCCVertexAttrib_Color, 4, GL_UNSIGNED_BYTE, GL_TRUE, kQuadSize, (void*)(offset &#; diff)); glDrawArrays(GL_TRIANGLE_STRIP, 0, 4); CC_INCREMENT_GL_DRAWS(1); } void CCSprite::setHSL(float h, float s, float l) { initHSL(); setH(h); setS(s); setL(l); } void CCSprite::setH(float h) { initHSL(); m_color_h = h; } void CCSprite::setS(float s) { initHSL(); m_color_s = s; } void CCSprite::setL(float l) { initHSL(); m_color_l = l; 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 的 updateBlendFunc中追加代码

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

在 CCSprite.cpp 的 setTexture中追加代码

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

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

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

步骤5.在cocos2dx 中添加自定义 shaders --- 改变 HSL 色调,饱和度, 亮度(cocos怎么用)

调用接口

[cpp] view plaincopy{ CCSprite* pSprite = CCSprite::create("Icon.png"); // -1 ~ 1 0无变化 pSprite->setS(-1); // position the sprite on the center of the screen pSprite->setPosition(ccp(visibleSize.width/2 &#; origin.x, visibleSize.height/2 &#; origin.y)); // add the sprite as a child to this layer this->addChild(pSprite, 0); }

-- ::| 分类: cocos2dx|举报|字号 订阅

步骤1.

准备 shaders文件- ccShad_Hsl.h

将它放入E:HSluZiLongcocos2d-x-2.2.1cocos2d-x-2.2.1cocos2dxshaders 目录下

步骤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 接口

[cpp] view plaincopyvoid initHSL(); void drawHSL(); void setHSL(float h, float s, float l); void setH(float h); void setS(float s); void setL(float l); float getH(void){ return m_color_h;} float getS(void){ return m_color_s;} float getL(void){ return m_color_l;} [cpp] view plaincopyvoid CCSprite::initHSL() { if(m_use_hsl == false) { m_use_hsl = true; setShaderProgram(CCShaderCache::sharedShaderCache()->programForKey(KCCShader_Position_hsl)); hLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddHue"); sLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddSat"); lLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddLig"); rLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddRed"); gLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddGreen"); bLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddBlue"); aLocation = glGetUniformLocation( getShaderProgram()->getProgram(), "AddAlpha"); } } void CCSprite::drawHSL() { ccBlendFunc blend = getBlendFunc(); ccGLBlendFunc(blend.src, blend.dst); getShaderProgram()->use(); getShaderProgram()->setUniformsForBuiltins(); getShaderProgram()->setUniformLocationWith1f(hLocation, m_color_h); getShaderProgram()->setUniformLocationWith1f(sLocation, m_color_s); getShaderProgram()->setUniformLocationWith1f(lLocation, m_color_l); getShaderProgram()->setUniformLocationWith1f(rLocation, _displayedColor.r/.f); getShaderProgram()->setUniformLocationWith1f(gLocation, _displayedColor.g/.f); getShaderProgram()->setUniformLocationWith1f(bLocation, _displayedColor.b/.f); m_color_a = this->getOpacity() / .f; getShaderProgram()->setUniformLocationWith1f(aLocation, m_color_a); ccGLBindTexture2D( getTexture()->getName()); ccGLEnableVertexAttribs(kCCVertexAttribFlag_PosColorTex ); #define kQuadSize sizeof(m_sQuad.bl) long offset = (long)&m_sQuad; // vertex int diff = offsetof( ccV3F_C4B_T2F, vertices); glVertexAttribPointer(kCCVertexAttrib_Position, 3, GL_FLOAT, GL_FALSE, kQuadSize, (void*) (offset &#; diff)); // texCoods diff = offsetof( ccV3F_C4B_T2F, texCoords); glVertexAttribPointer(kCCVertexAttrib_TexCoords, 2, GL_FLOAT, GL_FALSE, kQuadSize, (void*)(offset &#; diff)); // color diff = offsetof( ccV3F_C4B_T2F, colors); glVertexAttribPointer(kCCVertexAttrib_Color, 4, GL_UNSIGNED_BYTE, GL_TRUE, kQuadSize, (void*)(offset &#; diff)); glDrawArrays(GL_TRIANGLE_STRIP, 0, 4); CC_INCREMENT_GL_DRAWS(1); } void CCSprite::setHSL(float h, float s, float l) { initHSL(); setH(h); setS(s); setL(l); } void CCSprite::setH(float h) { initHSL(); m_color_h = h; } void CCSprite::setS(float s) { initHSL(); m_color_s = s; } void CCSprite::setL(float l) { initHSL(); m_color_l = l; 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 的 updateBlendFunc中追加代码

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

在 CCSprite.cpp 的 setTexture中追加代码

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

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

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

步骤5.

调用接口

[cpp] view plaincopy{ CCSprite* pSprite = CCSprite::create("Icon.png"); // -1 ~ 1 0无变化 pSprite->setS(-1); // position the sprite on the center of the screen pSprite->setPosition(ccp(visibleSize.width/2 &#; origin.x, visibleSize.height/2 &#; origin.y)); // add the sprite as a child to this layer this->addChild(pSprite, 0); }

Cocos2dx的截屏与遮罩 Cocos2dx3.2截取精灵部分;boolHelloWorld::init(){//////////////////////////////if(!Layer::init()){returnfalse;}SizevisibleSize=Director::getInstance()-getVisibleSize();Vec2origin=Director::getInst

cocos2dx菜单重叠按钮实现按层优先选择及透明过滤 众所周知,在cocos2d-x中,通过CCMenu(抱歉,笔者至今任然在用2.2.2的版本)创建的菜单,如果遇到数个按钮有重叠,当用户点击重叠区域(包括PNG图标中

cocos2dx中滚动界面和小滚动条同步的实现 在游戏中,经常会遇到滚动界面,或者滚动列表,在滚动时,为了给用户一个更好的体验,我们会想到在滚动界面的旁边加上一个小小的滚动条,让这

标签: cocos怎么用

本文链接地址:https://www.jiuchutong.com/biancheng/368960.html 转载请保留说明!

上一篇:Cocos2dx CCSprite CCSpriteFrame CCTexture2D CCAnimation学习总结

下一篇:Cocos2dx的截屏与遮罩(cocos2d schedule)

  • 应付销货方代垫运费计入什么科目
  • etc发票开票中
  • 标书的资金类型是什么
  • 增值税报表填写说明
  • 行政事业单位会计制度
  • 水泥销售成本怎么算
  • 房产租金收入是什么科目
  • 期初建账以前年度损益调整怎么转?
  • 购入材料时,会出现哪几种情况
  • 土地使用证明可以补办吗
  • 企业盈利后又亏损怎么算
  • 企业所得税减免优惠政策
  • 体检合同属于什么合同
  • 地税纳税人编码是什么
  • 增加以前年度收入是否需要更正申报年报
  • 电子普通发票进什么科目
  • 公司购买物品流程
  • 公司注销还需要登报吗
  • 技术服务费收入属于提供劳务收入吗
  • 失业保险退保怎么返
  • 汽车装饰用品大全进货
  • 出纳现金日记账怎么记账
  • 一般纳税人建筑服务税率是多少
  • 所得税招待费用
  • 股东不发工资只给员工钱
  • 备用金的会计分类
  • 开办费属于什么科目类别
  • w7系统怎么用
  • xshell怎么用vim
  • windows无法连接到system Events
  • ghost windows10安装教程
  • vue watch监听vuex数据
  • 耕地佔用税的缴纳期限
  • 附有销售退回条款的销售中,每一资产负债表日
  • 税务局关于免税资格的审核认定
  • vue区别
  • 买税盘的会计分录
  • 库存商品盘点表
  • 织梦tag标签怎么用
  • 研发人员旅游能计入研发费用吗
  • 公司贷款谁签字
  • mongodb安装教程win10
  • 网站维护费用
  • 税控盘有什么作用
  • 不符合资本化的长期借款利息计入什么科目
  • 冲减以前年度利润
  • 房地产开发企业分为几个等级
  • 购买会计软件如何入账
  • 收到招聘费发票怎么做账
  • 研发费用属于哪类会计科目
  • 应付账款不需要付情况说明
  • 亏损弥补的会计处理方法
  • 金税盘的维护费每年怎么抵扣
  • 企业增资的流程
  • 企业成立第二年有补贴吗
  • mysql中json格式是多少长度
  • 未知文件怎么删除
  • ubuntu系统中安装微信步骤
  • centos7 tcp6
  • win10web服务器在哪打开
  • Win10怎么打开屏幕键盘
  • win10触摸模式开启
  • windows升级后照片不见了
  • 红石cpu教程
  • windows安装node.js
  • 安卓应用程序数据
  • python自动报表
  • jquery弹出新窗口
  • 简述android应用的常用开发模式及其优缺点
  • android中启动service的方法有
  • android中edittext
  • python pil gif
  • Javascript & DHTML 实例编程(教程)基础知识
  • 浅谈如何实现乡村振兴论文
  • 西安养老保险申报
  • 税法税收保全的适用范围
  • 设计费需要交税吗
  • 计算当期免抵退税额
  • 新疆房车自驾营地
  • 浅谈企业所得税论文
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设