位置: 编程技术 - 正文

在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)

  • 小规模纳税人的企业所得税税率
  • 销售净收入咋算
  • 预提费用在资产负债表里写在哪
  • 收据大写十万元整怎么写标准
  • 营业额和营业收入区别举例
  • 手写报销单据格式图片
  • 个人出租商业用房
  • 变更注册资本的股东会决议范本
  • 固定资产拆除后账务处理
  • 收到银行退回的银行汇票多余款
  • 外贸企业0退税率的账务处理
  • 电商公司怎么开发票
  • 已经作废了的发票怎么查
  • 虚开进项税额转出会计分录
  • 资本公积转增资本会引起什么变化
  • 营改增后企业要交哪些税
  • 资管产品征税
  • 如何申报固定资产投资
  • 建设银行对公转账限额
  • 怎样接收电子承兑汇票流程视频
  • 事业单位坏账准备的计提方法
  • 运杂费计入什么科目
  • 为什么无形资产是非流动资产
  • php中的函数可以分为哪几种
  • 押金少退侵犯了哪条法律
  • 跨年销货退回账务处理
  • 视同销售成本如何确认?
  • 一借多贷的会计分录怎么写
  • 最小的电脑是多少寸的
  • 不能抵扣的发票可以做成本吗
  • 建筑安装发票可以外地开吗
  • 出口企业如何确认增值税收入
  • 工业企业应付会计工作内容
  • 核定征收注意事项
  • vite2.0 vue
  • 个税申报结果查询
  • 资产减值损失的借贷方向
  • 垃圾处理费计入办公费用吗
  • 织梦数据库连接失败的原因
  • PhoneGap was accuriqed by adobe
  • 国际货运代理可以分哪几类?
  • 送礼的烟酒去哪里买
  • 美金账户余额截图
  • 长期股权投资资本公积增加记哪个会计科目
  • 报销电话费计入什么科目
  • 以前年度费用未入账,现可以入账吗?
  • 已认证的红字发票要给购买方吗
  • 付款申请单如何转填记账凭证
  • 资产负债表中的货币资金怎么算
  • 损益类科目如何记忆
  • 汽车销售公司购入汽车会计分录
  • 金税盘每年服务费可以抵扣吗
  • 水果销售公司怎么起名字好听
  • 应交税费应交增值税已交税金怎么用
  • 应收账款转让会计分录 未实际收到对价
  • 工会经费怎么申报,怎么上交?
  • 工业企业营业税率
  • linux 查看numa
  • sql server数据库监控
  • centosgui
  • xp电脑如何在网页打开
  • mac睡眠后黑屏
  • win10正版授权图标
  • git 进阶
  • win8读不出u盘
  • windows打补丁后无法启动
  • win10移动版应用商店打不开
  • 嵌入式linux开发用什么语言
  • 一边做游戏一边学英语
  • 构造函数中super()的作用
  • vim tagbar
  • vue中怎么引入css
  • python的特点及应用范围
  • websocket npm
  • linux实现shell代码
  • 电梯维修费的税率
  • 江苏国税申报怎么操作流程
  • 税务局怎么增加购票员
  • 焦作国税局官网
  • 2021北京餐饮业发展趋势报告
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设