位置: 编程技术 - 正文

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

  • 应交代扣利息税
  • 临时用工的会计分录
  • 费用怎么分析
  • 换工作个税申报忘记更改
  • 负债的账面价值减去未来期间计算应纳税所得额
  • 企业所得税跨年度事项
  • 土地增值税清算管理规程
  • 报表的应付款太大怎么调?
  • 营业外支出计入
  • 存货暂估入账会引起存货账面价值发生增减变动吗
  • 研发设备一次性扣除账务处理
  • 企业借款给个人合法吗
  • 亏损弥补额的年数如何计算?
  • 简易计税的收入怎么做账
  • 预缴的附加税还可以扣减吗
  • 劳务派遣公司会扣工资吗
  • 企业捐赠现金支出应在哪个项目反应
  • 分公司注销时有未分配利润需要交税吗
  • 购买汽车可以开普通发票吗
  • 企业无形资产包括
  • iphone制造成本
  • 三代税款手续费支付比例
  • 罂粟是不是草果
  • PHP clearstatcache()函数详解
  • 采购涉及哪些部门
  • w10如何删除微软拼音
  • 农村自建房买卖怎样才合法
  • 乌鲁米耶湖春季湖水更深
  • 收到的担保费如何记账
  • 房地产销售未完工产品收入是含税的吗
  • nginx加php
  • 制造业工资计提
  • monolog php
  • php 抓取别的网站的内容
  • 资产减值损失和存货跌价准备有什么区别
  • 工程项目科学技术方法工具过程之间的关系
  • python里pip
  • vue2 diff算法
  • 原始凭证必要时可以涂改
  • 长期待摊费用是什么科目
  • 同一控制下企业合并和非同一控制下企业合并的区别
  • phpcms v9 getshell
  • 非货币性资产交换和债务重组的区别
  • 公司多交的社保费法律规定需要退还吗
  • 未确认融资费用摊销额怎么计算
  • 奖金是职工福利?
  • 出口转内销怎么做
  • 记账凭证应该是
  • 软件开发公司账一定按项目做吗
  • 提前报废固定资产需要补提折旧
  • 小规模纳税人利润如何缴税
  • 管家婆记账可以都有凭证做吗?
  • 固定资产折旧度怎么计算
  • 接受非货币性资产捐赠入账价值
  • 发票开多了如何做凭证?
  • 营业执照代办需要什么手续
  • ubuntu20.04配置
  • 如何在mac上保存文件
  • linux中vim命令详解
  • 如何关闭win8自带杀毒
  • 13寸的macbook
  • windows多屏显示
  • windows10升级后
  • opengl 生成图片
  • vs2010配置opengl
  • http状态码一览表
  • easyui选项卡
  • python网络爬虫程序
  • jqueryw3c
  • python调用python代码
  • ecmascript新特性
  • android ui自动化测试
  • 国家税务湖北税务局
  • 医保断交一年怎么续交
  • 济南市中区税务局办税大厅
  • 银行内部有遴选吗知乎
  • 国家税务网上办税平台
  • 宁波国税局几点上班几点下班
  • 出版社税费多少
  • 环保职责及管理范围
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设