亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? worleyshader.cpp

?? shrike is a utility application that acts as a testbed for shaders written in Sh
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
// Sh: A GPU metaprogramming language.//// Copyright 2003-2005 Serious Hack Inc.// // This library is free software; you can redistribute it and/or// modify it under the terms of the GNU Lesser General Public// License as published by the Free Software Foundation; either// version 2.1 of the License, or (at your option) any later version.//// This library is distributed in the hope that it will be useful,// but WITHOUT ANY WARRANTY; without even the implied warranty of// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU// Lesser General Public License for more details.//// You should have received a copy of the GNU Lesser General Public// License along with this library; if not, write to the Free Software// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, // MA  02110-1301, USA//////////////////////////////////////////////////////////////////////////////#include <sh/sh.hpp>#include <sh/shutil.hpp>#include <iostream>#include "Shader.hpp"#include "Globals.hpp"using namespace SH;using namespace ShUtil;#include "util.hpp"class WorleyShader : public Shader {public:  WorleyShader(std::string name, bool tex)    : Shader(std::string("Worley: ") + (tex ? " Texture Hash: " : " Procedural: ") + name), useTexture(tex) {}  virtual ~WorleyShader() {}  ShProgram vertex() { return vsh;}  ShProgram fragment() { return fsh;}  // sets default vertex shader, phong fsh   bool init();   // sets colours, specular, worley function specific to each subclass and uses algebra to   // add on to the default phong shader  virtual void initfsh() = 0;  ShProgram vsh, fsh;   // uniforms used by subclasses  ShAttrib1f param, freq, exponent;  /*static*/ ShAttrib4f coeff;  ShColor3f color1, color2;  //ShUtil::ShWorleyMetric metric;  bool useTexture;};//ShAttrib4f WorleyShader::coeff;bool WorleyShader::init(){  std::cerr << "Initializing " << name() << std::endl;  param.name("param");   param = .5;           param.range(0.0f, 1.0f);  freq.name("Worley frequency");  freq = 16.0;  freq.range(0.1f, 128.0f);  coeff.name("Worley coefficient");  coeff = ShConstAttrib4f(1.0, 0.0, 0.0, 0.0);  coeff.range(-3.0f, 3.0f);  exponent.name("specular exponent");  exponent = 35.0;      exponent.range(10.0f, 500.0f);  color1.name("color1");  color1.range(-2.0f, 2.0f);  color2.name("color2");  color2.range(-2.0f, 2.0f);  vsh = ShKernelLib::shVsh(Globals::mv, Globals::mvp, 1) << shExtract("lightPos") << Globals::lightPos;   ShConstColor3f lightColor(1.0f, 1.0f, 1.0f);  fsh = ShKernelSurface::phong<ShColor3f>() << shExtract("specExp") << exponent;  fsh = fsh << shExtract("irrad") << lightColor;  initfsh();  return true;}class GradientWorley: public WorleyShader {public:  GradientWorley(bool useTexture): WorleyShader("Gradients", useTexture) {}  void initfsh()  {    DefaultGenFactory<2, float> genFactory(useTexture);    DistSqGradientPropFactory<2, float> propFactory;     ShProgram worleysh = shWorley<4>(&genFactory, &propFactory);     worleysh = worleysh << (shMul<ShTexCoord2f>("texcoord", "freq", "texcoord") << fillcast<2>(freq));    ShAttrib1f SH_DECL(bumpScale) = ShConstAttrib1f(1.0f);    bumpScale.range(-10.0f, 10.0f);    color1 = ShColor3f(1.0, 0.0, 0.0);    color2 =  ShColor3f(0.0, 1.0, 0.0);    ShProgram color = SH_BEGIN_PROGRAM("gpu:fragment") {      ShInputAttrib4f result[3]; // result[0] holds distances, [1], [2] hold the gradient      ShInputPosition4f SH_DECL(posh);      ShOutputColor3f SH_NAMEDECL(resultColor, "result");              ShAttrib2f gradient;      gradient(0) = dot(result[1], coeff);      gradient(1) = dot(result[2], coeff);      resultColor = bumpScale * (color1 * gradient(0) + color2 * gradient(1));     } SH_END;    fsh = color << worleysh;    vsh = namedAlign(vsh, fsh);  }};class OrganicWorley: public WorleyShader {public:  OrganicWorley(bool useTexture): WorleyShader("Organic", useTexture) {}  void initfsh()  {    DefaultGenFactory<2, float> genFactory(useTexture);    DistSqGradientPropFactory<2, float> propFactory;     ShProgram worleysh = shWorley<4>(&genFactory, &propFactory);     worleysh = worleysh << (shMul<ShTexCoord2f>("texcoord", "freq", "texcoord") << fillcast<2>(freq));    ShAttrib1f SH_DECL(bumpScale) = ShConstAttrib1f(3.0f);    bumpScale.range(-10.0f, 10.0f);    color1 = ShColor3f(0.4, 0.0, 0.0);    color2 =  ShColor3f(0.2, 0.6, 0.2);    ShConstAttrib1f ZERO(0.0f);    ShConstAttrib1f ONE(1.0f);    // TODO when bump mapper kernel properly supports transformation btw    // coordinate spaces and handles all used auxillary vectors (hv, etc.)    // remove most of this code.    ShProgram colorAndBump = SH_BEGIN_PROGRAM() {      ShInputAttrib4f result[3]; // 0 holds distances, 1-2 hold gradient      ShInputVector3f SH_DECL(tangent) = normalize(tangent);      ShInputVector3f SH_DECL(tangent2) = normalize(tangent2);      ShInputVector3f SH_DECL(lightVec) = normalize(lightVec);      ShInOutNormal3f SH_DECL(normal) = normalize(normal);       ShOutputColor3f SH_DECL(kd);      ShOutputColor3f SH_DECL(ks);      ShOutputVector3f SH_DECL(halfVec);      ShAttrib1f dist = dot(coeff, result[0]);      ShAttrib2f grad;      grad(0) = dot(coeff, result[1]);      grad(1) = dot(coeff, result[2]);      kd = ks = lerp(clamp(dist, ZERO, ONE), color1, color2);      normal += bumpScale * (grad(0) * tangent + grad(1) * tangent2);      normal = normalize(normal);      halfVec = 0.5f * (normal + lightVec);     } SH_END;    fsh = namedConnect((colorAndBump << worleysh), fsh);    vsh = namedAlign(vsh, fsh);  }};class BlueOrbWorley: public WorleyShader {public:  BlueOrbWorley(bool useTexture): WorleyShader("BlueOrb", useTexture) {}  void initfsh()  {    DefaultGenFactory<2, float> genFactory(useTexture);    Dist_InfGradientPropFactory<2, float> propFactory;     Dist_1PropFactory<2, float> dist1Factory;    coeff = ShConstAttrib4f(-1.0f, 1.0f, 0.0f, 0.0f);    ShAttrib1f SH_DECL(frequency) = ShConstAttrib1f(16.0f);    frequency.range(0.0f, 256.0f);    ShProgram worleysh = shWorley<4>(&genFactory, &propFactory);     worleysh = worleysh << (shMul<ShTexCoord2f>("texcoord", "freq", "texcoord") << fillcast<2>(freq));    ShAttrib4f SH_DECL(innerCoeff) = coeff;     ShAttrib1f SH_DECL(innerFreq) = ShConstAttrib1f(32.0f);    innerFreq.range(0.0f, 256.0f);    ShProgram innersh = shWorley<4>(&genFactory, &dist1Factory);    innersh = innersh << (shMul<ShTexCoord2f>("texcoord", "freq", "texcoord") << fillcast<2>(innerFreq));    worleysh = namedCombine(worleysh, innersh);    ShAttrib1f SH_DECL(bumpScale) = ShConstAttrib1f(1.0f);    bumpScale.range(-10.0f, 10.0f);    ShColor3f SH_DECL(latticeColor) = ShColor3f(0.0f, 0.0f, 0.0f);    ShColor3f SH_DECL(latticeSpecular) = ShColor3f(0.5f, 0.1f, 0.1f);    color1 = ShColor3f(0.0f, 0.0f, 0.0f);    color2 = ShColor3f(0.25f, 0.25f, 1.0f);    ShColor3f SH_DECL(specular) = ShColor3f(0.3f, 0.3f, 0.3f);    ShAttrib1f SH_NAMEDECL(threshold, "Less Than Threshold") = ShConstAttrib1f(0.2f);    threshold.range(-1.0f, 1.0f);    ShAttrib1f SH_NAMEDECL(threshold2, "Greater Than Threshold") = ShConstAttrib1f(1.0f);    threshold2.range(-1.0f, 1.0f);    ShConstAttrib1f ZERO(0.0f);    ShConstAttrib1f ONE(1.0f);    ShProgram colorAndBump = SH_BEGIN_PROGRAM() {      ShInputAttrib4f result[3];      ShInputAttrib4f innerResult;      ShInputVector3f SH_DECL(tangent) = normalize(tangent);      ShInputVector3f SH_DECL(tangent2) = normalize(tangent2);      ShInputVector3f SH_DECL(lightVec) = normalize(lightVec);      ShInOutNormal3f SH_DECL(normal) = normalize(normal);       ShOutputColor3f SH_DECL(kd);      ShOutputColor3f SH_DECL(ks);      ShOutputVector3f SH_DECL(halfVec);      // determine if we're in one of the bumps in the outer lattice work      ShAttrib1f dist = coeff | result[0];      ShAttrib1f inBump = (dist < threshold) + (dist > threshold2);       // figure out inner colour and select kd/ks based on whether we're in the bumps       ShColor3f innerColor = lerp(innerCoeff | innerResult, color1, color2);      kd = lerp(inBump, latticeColor, innerColor);       ks = lerp(inBump, latticeSpecular, specular);      // do the bump mapping (TODO use bump function/nibble)      ShAttrib2f grad;      grad(0) = dot(coeff, result[1]);      grad(1) = dot(coeff, result[2]);      normal += inBump * bumpScale * (grad(0) * tangent + grad(1) * tangent2);      normal = normalize(normal);      halfVec = 0.5f * (normal + lightVec);     } SH_END;    fsh = namedConnect((colorAndBump << worleysh), fsh);    vsh = namedAlign(vsh, fsh);  }};class PolkaDotWorley: public WorleyShader {public:  PolkaDotWorley(bool useTexture): WorleyShader("Polka Dot", useTexture) {}  void initfsh()  {    ShProgram worleysh = shWorley<4, 2, float>(useTexture);    worleysh = worleysh << (shMul<ShTexCoord2f>("texcoord", "freq", "texcoord") << fillcast<2>(freq));    worleysh = (shDot<ShAttrib4f>() << coeff) << worleysh;    // make polkadots by clamping the scalar result from worley    ShProgram polkash = SH_BEGIN_PROGRAM() {      ShInOutAttrib1f SH_DECL(scalar) = clamp((scalar + param - 0.75f) * 30.0f, 0.0f, 1.0f);     } SH_END;    worleysh = polkash << worleysh;    color1 = ShColor3f(0.27, 0.35, 0.45);    color2 =  ShColor3f(1.0, 0.7, 0.0);    ShColor3f specularColor(0.5, 0.5, 0.5);    ShProgram colorsh = shLerp<ShColor3f, ShAttrib1f>("kd") << color1 << color2;  // kd is a lerp based on the worley scalar    colorsh = colorsh & ( keep<ShColor3f>("ks") << specularColor);     fsh = fsh << colorsh << worleysh;    vsh = namedAlign(vsh, fsh);  }};class LavaWorley: public WorleyShader {public:  LavaWorley(bool useTexture): WorleyShader("Lava", useTexture) {}  void initfsh()  {    coeff = ShConstAttrib4f(-1, 1.2, 0, 0);    ShAttrib4f SH_NAMEDECL(coeff2, "Worley coefficient 2") = ShConstAttrib4f(0, 1, 1, 0);    ShAttrib1f SH_NAMEDECL(freq2, "Worley frequency 2") = freq * 2.131313f;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品美女久久久久aⅴ国产馆| 免费观看日韩电影| 亚洲欧美日韩国产综合| 午夜久久福利影院| 国产中文一区二区三区| 精品视频色一区| 国产精品久久久一本精品| 日韩高清欧美激情| 在线视频你懂得一区| 国产欧美视频一区二区| 免费人成精品欧美精品| 欧美在线免费播放| 国产精品网友自拍| 韩国成人精品a∨在线观看| 欧美日韩卡一卡二| 亚洲另类中文字| 成人午夜视频在线| 精品国产乱码久久久久久闺蜜| 亚洲一区二区三区美女| av电影在线观看一区| 国产视频一区在线播放| 国产精品亚洲人在线观看| 欧美日韩一二三| 最新国产精品久久精品| 国产激情一区二区三区四区 | 久久99精品国产麻豆婷婷| 欧美日韩一区精品| 亚洲一区二区三区四区在线观看| 国产成人av资源| 国产三级精品三级| 国产高清成人在线| 国产精品三级电影| 成人免费av在线| 中文幕一区二区三区久久蜜桃| 国产一区二区久久| 国产日韩欧美麻豆| 岛国精品一区二区| 国产精品成人免费| youjizz久久| 日韩一区有码在线| 色诱亚洲精品久久久久久| ...xxx性欧美| 欧美日韩三级在线| 麻豆一区二区三区| 久久影院午夜论| 成人激情小说乱人伦| 亚洲人成精品久久久久| 欧洲一区在线观看| 舔着乳尖日韩一区| 精品国产区一区| 99久久亚洲一区二区三区青草| 日韩理论电影院| 337p亚洲精品色噜噜噜| 激情综合一区二区三区| 国产农村妇女精品| 色8久久精品久久久久久蜜| 亚洲图片欧美一区| 日韩一级二级三级| 成人av电影在线| 亚洲第一激情av| 精品sm捆绑视频| 色综合久久天天综合网| 日本成人中文字幕在线视频| 精品久久久久久最新网址| 91电影在线观看| 日韩精品1区2区3区| 久久久久久一二三区| 在线看日本不卡| 久久99精品国产91久久来源| 自拍偷拍欧美精品| 日韩限制级电影在线观看| 成人黄色av电影| 日韩一区精品字幕| 日韩美女久久久| 精品久久久久久久久久久院品网 | 香蕉加勒比综合久久| 久久久综合网站| 欧美午夜精品久久久久久超碰| 精久久久久久久久久久| 一区二区三区在线影院| 欧美mv和日韩mv国产网站| 在线视频中文字幕一区二区| 国产在线精品免费| 亚洲一区二区成人在线观看| 久久亚洲欧美国产精品乐播| 欧美性猛交一区二区三区精品| 国产一区二区不卡老阿姨| 亚洲大片一区二区三区| 中文字幕亚洲综合久久菠萝蜜| 51精品国自产在线| 日本道色综合久久| 成人免费视频一区二区| 免费人成在线不卡| 亚洲成人福利片| 亚洲精品视频在线| 国产精品丝袜91| 337p日本欧洲亚洲大胆色噜噜| 欧美午夜不卡在线观看免费| proumb性欧美在线观看| 国产成人在线观看免费网站| 男女男精品网站| 亚洲sss视频在线视频| 亚洲免费观看高清完整版在线观看熊| 337p日本欧洲亚洲大胆精品 | 欧美亚洲一区二区在线| www.欧美.com| 成人免费视频视频| 国产高清视频一区| 国产九色sp调教91| 久色婷婷小香蕉久久| 日本伊人色综合网| 午夜亚洲福利老司机| 亚洲小少妇裸体bbw| 亚洲免费观看高清完整版在线观看熊| 国产精品久久综合| 国产精品美女视频| 一区二区中文字幕在线| 国产精品大尺度| 亚洲精品写真福利| 亚洲一二三级电影| 石原莉奈在线亚洲二区| 日本不卡一二三| 蜜桃一区二区三区四区| 蜜臀a∨国产成人精品| 黄色资源网久久资源365| 国内精品视频一区二区三区八戒| 美女诱惑一区二区| 国产精品99久久久久久宅男| 国产一区二区三区最好精华液| 狠狠色狠狠色综合| 不卡的电影网站| 91福利在线导航| 欧美一级艳片视频免费观看| 欧美成人猛片aaaaaaa| 久久精品在线免费观看| 国产精品久久午夜夜伦鲁鲁| 亚洲精品亚洲人成人网| 日韩电影在线一区二区三区| 黑人精品欧美一区二区蜜桃| 成人黄色国产精品网站大全在线免费观看 | 久久久久久久久久看片| 国产日韩欧美综合一区| 亚洲人妖av一区二区| 亚洲国产视频在线| 久久成人麻豆午夜电影| 成人av电影观看| 777奇米四色成人影色区| 久久久噜噜噜久久中文字幕色伊伊| 中文字幕久久午夜不卡| 亚洲自拍偷拍麻豆| 黄色日韩三级电影| 欧洲中文字幕精品| 久久久蜜桃精品| 亚洲aaa精品| 国产高清不卡二三区| 欧美日韩黄色一区二区| 久久久777精品电影网影网 | 一区二区三区免费在线观看| 日韩精品欧美精品| 99国产精品久久久久| 欧美成人一区二区| 亚洲精品视频在线观看免费| 国内精品视频666| 精品视频在线看| 中文字幕一区二区三区视频 | 欧美在线不卡视频| 国产网红主播福利一区二区| 亚欧色一区w666天堂| 成人av先锋影音| 日韩免费观看高清完整版在线观看| 中文字幕在线一区免费| 久久99精品久久只有精品| 91视视频在线观看入口直接观看www | 成人免费高清视频| 日韩欧美另类在线| 亚洲成av人片| 欧美日韩一区精品| 亚洲日本va午夜在线影院| 国产福利一区二区| 欧美sm极限捆绑bd| 三级成人在线视频| 在线精品国精品国产尤物884a| 国产日韩在线不卡| 国产麻豆一精品一av一免费 | 日韩视频一区二区在线观看| 有码一区二区三区| 波多野结衣91| 国产精品初高中害羞小美女文| 国内久久婷婷综合| 日韩欧美一区二区视频| 日韩 欧美一区二区三区| 欧美久久高跟鞋激| 亚洲 欧美综合在线网络| 精品视频全国免费看| 亚洲卡通欧美制服中文| 日本道免费精品一区二区三区| 亚洲美女区一区| 91丨porny丨蝌蚪视频| 亚洲欧美偷拍另类a∨色屁股| 不卡视频一二三四|