mirror of
https://github.com/PixarAnimationStudios/OpenSubdiv
synced 2025-01-11 00:50:10 +00:00
Merge branch '358' of https://github.com/ielillo/OpenSubdiv into ielillo-358
Conflicts: opensubdiv/far/stencilBuilder.cpp
This commit is contained in:
commit
62b7197389
@ -22,6 +22,8 @@
|
||||
// language governing permissions and limitations under the Apache License.
|
||||
//
|
||||
|
||||
#define CL_USE_DEPRECATED_OPENCL_2_0_APIS
|
||||
|
||||
#include "clDeviceContext.h"
|
||||
|
||||
#if defined(_WIN32)
|
||||
@ -41,6 +43,8 @@
|
||||
#include <CL/cl_d3d11.h>
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
#define message(...) // fprintf(stderr, __VA_ARGS__)
|
||||
#define error(...) fprintf(stderr, __VA_ARGS__)
|
||||
|
||||
|
@ -143,8 +143,8 @@ GLFrameBuffer::compileProgram(char const * src, char const * defines) {
|
||||
|
||||
GLuint program = glCreateProgram();
|
||||
|
||||
static char const versionStr[] = "#version 330\n",
|
||||
vtxDefineStr[] = "#define IMAGE_VERTEX_SHADER\n",
|
||||
const std::string &versionStr = GLUtils::GetShaderVersionInclude();
|
||||
static char const vtxDefineStr[] = "#define IMAGE_VERTEX_SHADER\n",
|
||||
fragDefineStr[] = "#define IMAGE_FRAGMENT_SHADER\n";
|
||||
|
||||
std::string vertexSrc = std::string(versionStr) + vtxDefineStr + (defines ? defines : "") + src;
|
||||
@ -171,7 +171,8 @@ GLFrameBuffer::compileProgram(char const * src, char const * defines) {
|
||||
delete[] infoLog;
|
||||
}
|
||||
|
||||
#if defined(GL_ARB_separate_shader_objects) or defined(GL_VERSION_4_1)
|
||||
|
||||
if (GLUtils::GL_ARBSeparateShaderObjectsOrGL_VERSION_4_1()){
|
||||
GLint colorMap = glGetUniformLocation(program, "colorMap");
|
||||
if (colorMap != -1)
|
||||
glProgramUniform1i(program, colorMap, 0); // GL_TEXTURE0
|
||||
@ -183,20 +184,21 @@ GLFrameBuffer::compileProgram(char const * src, char const * defines) {
|
||||
GLint depthMap = glGetUniformLocation(program, "depthMap");
|
||||
if (depthMap != -1)
|
||||
glProgramUniform1i(program, depthMap, 2); // GL_TEXTURE2
|
||||
#else
|
||||
}
|
||||
else{
|
||||
glUseProgram(program);
|
||||
GLint colorMap = glGetUniformLocation(program, "colorMap");
|
||||
if (colorMap != -1)
|
||||
glUniform1i(colorMap, 0); // GL_TEXTURE0
|
||||
|
||||
GLint colorMap = glGetUniformLocation(program, "normalMap");
|
||||
GLint normalMap = glGetUniformLocation(program, "normalMap");
|
||||
if (normalMap != -1)
|
||||
glUniform1i(normalMap, 1); // GL_TEXTURE1
|
||||
|
||||
GLint depthMap = glGetUniformLocation(program, "depthMap");
|
||||
if (depthMap != -1)
|
||||
glUniform1i(depthMap, 2); // GL_TEXTURE2
|
||||
#endif
|
||||
}
|
||||
|
||||
return program;
|
||||
}
|
||||
|
@ -23,6 +23,7 @@
|
||||
//
|
||||
|
||||
#include "glShaderCache.h"
|
||||
#include "glUtils.h"
|
||||
|
||||
#include <vector>
|
||||
#include <osd/opengl.h>
|
||||
@ -41,14 +42,22 @@ GLDrawConfig::~GLDrawConfig() {
|
||||
|
||||
bool
|
||||
GLDrawConfig::CompileAndAttachShader(GLenum shaderType,
|
||||
const std::string &source) {
|
||||
const std::string &source) {
|
||||
|
||||
|
||||
GLuint shader = glCreateShader(shaderType);
|
||||
|
||||
#if 0
|
||||
const char *sources[2];
|
||||
sources[0] = _version.c_str();
|
||||
sources[1] = source.c_str();
|
||||
#endif
|
||||
|
||||
glShaderSource(shader, 2, sources, NULL);
|
||||
std::string sources = _version + source;
|
||||
|
||||
const char *src = sources.c_str();
|
||||
|
||||
glShaderSource(shader, 1, &src, NULL);
|
||||
glCompileShader(shader);
|
||||
|
||||
GLint status;
|
||||
|
@ -22,6 +22,8 @@
|
||||
// language governing permissions and limitations under the Apache License.
|
||||
//
|
||||
|
||||
#include <sstream>
|
||||
#include <string>
|
||||
#include "glUtils.h"
|
||||
|
||||
namespace GLUtils {
|
||||
@ -57,7 +59,7 @@ CompileShader(GLenum shaderType, const char *source) {
|
||||
bool
|
||||
SupportsAdaptiveTessellation() {
|
||||
#ifdef OSD_USES_GLEW
|
||||
return (glewIsSupported("GL_ARB_tessellation_shader") == GL_TRUE);
|
||||
return glewGetExtension("GL_ARB_tessellation_shader") == GL_TRUE;
|
||||
#else
|
||||
#if defined(GL_ARB_tessellation_shader) || defined(GL_VERSION_4_0)
|
||||
return true;
|
||||
@ -67,4 +69,102 @@ SupportsAdaptiveTessellation() {
|
||||
#endif
|
||||
}
|
||||
|
||||
///Helper function that parses the open gl version string, retrieving the major
|
||||
///and minor version from it.
|
||||
void GetMajorMinorVersion(int *major, int *minor){
|
||||
static bool initialized = false;
|
||||
int _major = -1, _minor = -1;
|
||||
if (!initialized || _major == -1 || _minor == -1){
|
||||
const GLubyte *ver = glGetString(GL_SHADING_LANGUAGE_VERSION);
|
||||
if (!ver){
|
||||
_major = -1;
|
||||
_minor = -1;
|
||||
}
|
||||
else{
|
||||
std::string major_str(ver, ver + 1);
|
||||
std::string minor_str(ver + 2, ver + 3);
|
||||
std::stringstream ss;
|
||||
ss << major_str << " " << minor_str;
|
||||
ss >> _major;
|
||||
ss >> _minor;
|
||||
}
|
||||
initialized = true;
|
||||
}
|
||||
*major = _major;
|
||||
*minor = _minor;
|
||||
|
||||
}
|
||||
|
||||
/** Gets the shader version based on the current opengl version and returns
|
||||
* it in a string form */
|
||||
|
||||
const std::string &GetShaderVersion(){
|
||||
static bool initialized = false;
|
||||
static std::string shader_version;
|
||||
if (!initialized){
|
||||
|
||||
int major, minor;
|
||||
GetMajorMinorVersion(&major, &minor);
|
||||
int version_number = major * 10 + minor;
|
||||
switch (version_number){
|
||||
case 20:
|
||||
shader_version = "110";
|
||||
break;
|
||||
case 21:
|
||||
shader_version = "120";
|
||||
break;
|
||||
case 30:
|
||||
shader_version = "130";
|
||||
break;
|
||||
case 31:
|
||||
shader_version = "140";
|
||||
break;
|
||||
case 32:
|
||||
shader_version = "150";
|
||||
break;
|
||||
default:
|
||||
std::stringstream ss;
|
||||
ss << version_number;
|
||||
shader_version = ss.str() + "0";
|
||||
break;
|
||||
}
|
||||
initialized = true;
|
||||
}
|
||||
return shader_version;
|
||||
}
|
||||
|
||||
/* Generates the version defintion needed by the glsl shaders based on the
|
||||
* opengl string
|
||||
*/
|
||||
const std::string &GetShaderVersionInclude(){
|
||||
static bool initialized = false;
|
||||
static std::string include;
|
||||
if (!initialized){
|
||||
include = "#version " + GetShaderVersion() + "\n";
|
||||
initialized = true;
|
||||
}
|
||||
return include;
|
||||
}
|
||||
|
||||
bool GL_ARBSeparateShaderObjectsOrGL_VERSION_4_1(){
|
||||
#if defined(OSD_USES_GLEW)
|
||||
bool initialized = false, uses = false;
|
||||
if (!initialized){
|
||||
uses = glewGetExtension("GL_ARB_separate_shader_objects") ||
|
||||
(GLEW_VERSION_4_1
|
||||
&& glewGetExtension("GL_ARB_tessellation_shader"));
|
||||
initialized = true;
|
||||
}
|
||||
return uses;
|
||||
#else
|
||||
#if defined(GL_ARB_separate_shader_objects) || defined(GL_VERSION_4_1)
|
||||
return true;
|
||||
#else
|
||||
return false;
|
||||
#endif
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
|
||||
} // namesapce GLUtils
|
||||
|
@ -39,6 +39,15 @@ GLuint CompileShader(GLenum shaderType, const char *source);
|
||||
|
||||
bool SupportsAdaptiveTessellation();
|
||||
|
||||
void GetMajorMinorVersion(int *major, int *minor);
|
||||
|
||||
|
||||
const std::string &GetShaderVersion();
|
||||
|
||||
const std::string &GetShaderVersionInclude();
|
||||
|
||||
bool GL_ARBSeparateShaderObjectsOrGL_VERSION_4_1();
|
||||
|
||||
};
|
||||
|
||||
#endif // OPENSUBDIV_EXAMPLES_GL_UTILS_H
|
||||
|
@ -92,16 +92,48 @@ OpenSubdiv::Osd::GLLegacyGregoryPatchTable *g_legacyGregoryPatchTable = NULL;
|
||||
#include "../common/glHud.h"
|
||||
#include "../common/glUtils.h"
|
||||
#include "../common/objAnim.h"
|
||||
#include "../common/patchColors.h"
|
||||
#include "../common/glShaderCache.h"
|
||||
|
||||
#include <osd/glslPatchShaderSource.h>
|
||||
static const char *shaderSource =
|
||||
|
||||
|
||||
/* Function to get the correct shader file based on the opengl version.
|
||||
The implentation varies depending if glew is available or not. In case
|
||||
is available the capabilities are queried during execution and the correct
|
||||
source is returned. If glew in not available during compile time the version
|
||||
is determined*/
|
||||
static const char *shaderSource(){
|
||||
#if not defined(OSD_USES_GLEW)
|
||||
|
||||
static const char *res =
|
||||
#if defined(GL_ARB_tessellation_shader) || defined(GL_VERSION_4_0)
|
||||
#include "shader.gen.h"
|
||||
#include "shader.gen.h"
|
||||
#else
|
||||
#include "shader_gl3.gen.h"
|
||||
#include "shader_gl3.gen.h"
|
||||
#endif
|
||||
;
|
||||
#else
|
||||
static char *res = NULL;
|
||||
if (!res){
|
||||
static char *gen =
|
||||
#include "shader.gen.h"
|
||||
;
|
||||
static char *gen3 =
|
||||
#include "shader_gl3.gen.h"
|
||||
;
|
||||
//Determine the shader file to use. Since some opengl implementations
|
||||
//define that an extension is available but not an implementation
|
||||
//for it you cannnot trust in the glew header definitions to know that is
|
||||
//available, but you need to query it during runtime.
|
||||
if (GLUtils::SupportsAdaptiveTessellation())
|
||||
res = gen;
|
||||
else
|
||||
res = gen3;
|
||||
}
|
||||
#endif
|
||||
return res;
|
||||
|
||||
|
||||
}
|
||||
|
||||
#include <cfloat>
|
||||
#include <vector>
|
||||
@ -233,6 +265,7 @@ struct Program
|
||||
GLuint attrColor;
|
||||
} g_defaultProgram;
|
||||
|
||||
|
||||
// XXX:
|
||||
// this struct meant to be used as a stopgap entity until we fully implement
|
||||
// face-varying stuffs into patch table.
|
||||
@ -293,28 +326,17 @@ checkGLErrors(std::string const & where = "")
|
||||
}
|
||||
}
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
static GLuint
|
||||
compileShader(GLenum shaderType, const char *source)
|
||||
{
|
||||
GLuint shader = glCreateShader(shaderType);
|
||||
glShaderSource(shader, 1, &source, NULL);
|
||||
glCompileShader(shader);
|
||||
checkGLErrors("compileShader");
|
||||
return shader;
|
||||
}
|
||||
|
||||
|
||||
|
||||
static bool
|
||||
linkDefaultProgram() {
|
||||
|
||||
#if defined(GL_ARB_tessellation_shader) || defined(GL_VERSION_4_0)
|
||||
#define GLSL_VERSION_DEFINE "#version 400\n"
|
||||
#else
|
||||
#define GLSL_VERSION_DEFINE "#version 150\n"
|
||||
#endif
|
||||
const std::string glsl_version = GLUtils::GetShaderVersionInclude();
|
||||
|
||||
static const char *vsSrc =
|
||||
GLSL_VERSION_DEFINE
|
||||
|
||||
static const std::string vsSrc =
|
||||
glsl_version +
|
||||
"in vec3 position;\n"
|
||||
"in vec3 color;\n"
|
||||
"out vec4 fragColor;\n"
|
||||
@ -325,8 +347,8 @@ linkDefaultProgram() {
|
||||
" vec4(position, 1);\n"
|
||||
"}\n";
|
||||
|
||||
static const char *fsSrc =
|
||||
GLSL_VERSION_DEFINE
|
||||
static const std::string fsSrc =
|
||||
glsl_version +
|
||||
"in vec4 fragColor;\n"
|
||||
"out vec4 color;\n"
|
||||
"void main() {\n"
|
||||
@ -334,8 +356,8 @@ linkDefaultProgram() {
|
||||
"}\n";
|
||||
|
||||
GLuint program = glCreateProgram();
|
||||
GLuint vertexShader = compileShader(GL_VERTEX_SHADER, vsSrc);
|
||||
GLuint fragmentShader = compileShader(GL_FRAGMENT_SHADER, fsSrc);
|
||||
GLuint vertexShader = GLUtils::CompileShader(GL_VERTEX_SHADER, vsSrc.c_str());
|
||||
GLuint fragmentShader = GLUtils::CompileShader(GL_FRAGMENT_SHADER, fsSrc.c_str());
|
||||
|
||||
glAttachShader(program, vertexShader);
|
||||
glAttachShader(program, fragmentShader);
|
||||
@ -908,12 +930,9 @@ public:
|
||||
using namespace OpenSubdiv;
|
||||
|
||||
// compile shader program
|
||||
#if defined(GL_ARB_tessellation_shader) || defined(GL_VERSION_4_0)
|
||||
const char *glslVersion = "#version 400\n";
|
||||
#else
|
||||
const char *glslVersion = "#version 330\n";
|
||||
#endif
|
||||
GLDrawConfig *config = new GLDrawConfig(glslVersion);
|
||||
|
||||
|
||||
GLDrawConfig *config = new GLDrawConfig(GLUtils::GetShaderVersionInclude().c_str());
|
||||
|
||||
Far::PatchDescriptor::Type type = effectDesc.desc.GetType();
|
||||
|
||||
@ -995,7 +1014,7 @@ public:
|
||||
ss << common
|
||||
// enable local vertex shader
|
||||
<< (effectDesc.desc.IsAdaptive() ? "" : "#define VERTEX_SHADER\n")
|
||||
<< shaderSource
|
||||
<< shaderSource()
|
||||
<< Osd::GLSLPatchShaderSource::GetVertexShaderSource(type);
|
||||
config->CompileAndAttachShader(GL_VERTEX_SHADER, ss.str());
|
||||
ss.str("");
|
||||
@ -1003,14 +1022,14 @@ public:
|
||||
if (effectDesc.desc.IsAdaptive()) {
|
||||
// tess control shader
|
||||
ss << common
|
||||
<< shaderSource
|
||||
<< shaderSource()
|
||||
<< Osd::GLSLPatchShaderSource::GetTessControlShaderSource(type);
|
||||
config->CompileAndAttachShader(GL_TESS_CONTROL_SHADER, ss.str());
|
||||
ss.str("");
|
||||
|
||||
// tess eval shader
|
||||
ss << common
|
||||
<< shaderSource
|
||||
<< shaderSource()
|
||||
<< Osd::GLSLPatchShaderSource::GetTessEvalShaderSource(type);
|
||||
config->CompileAndAttachShader(GL_TESS_EVALUATION_SHADER, ss.str());
|
||||
ss.str("");
|
||||
@ -1019,14 +1038,14 @@ public:
|
||||
// geometry shader
|
||||
ss << common
|
||||
<< "#define GEOMETRY_SHADER\n"
|
||||
<< shaderSource;
|
||||
<< shaderSource();
|
||||
config->CompileAndAttachShader(GL_GEOMETRY_SHADER, ss.str());
|
||||
ss.str("");
|
||||
|
||||
// fragment shader
|
||||
ss << common
|
||||
<< "#define FRAGMENT_SHADER\n"
|
||||
<< shaderSource;
|
||||
<< shaderSource();
|
||||
config->CompileAndAttachShader(GL_FRAGMENT_SHADER, ss.str());
|
||||
ss.str("");
|
||||
|
||||
@ -1326,6 +1345,7 @@ display() {
|
||||
|
||||
GLenum primType = bindProgram(GetEffect(), patch);
|
||||
|
||||
|
||||
glDrawElements(primType,
|
||||
patch.GetNumPatches() * desc.GetNumControlVertices(),
|
||||
GL_UNSIGNED_INT,
|
||||
@ -1784,24 +1804,16 @@ callbackErrorGLFW(int error, const char* description) {
|
||||
}
|
||||
//------------------------------------------------------------------------------
|
||||
static void
|
||||
setGLCoreProfile() {
|
||||
setGLCoreProfile(int major, int minor) {
|
||||
#define glfwOpenWindowHint glfwWindowHint
|
||||
#define GLFW_OPENGL_VERSION_MAJOR GLFW_CONTEXT_VERSION_MAJOR
|
||||
#define GLFW_OPENGL_VERSION_MINOR GLFW_CONTEXT_VERSION_MINOR
|
||||
|
||||
glfwOpenWindowHint(GLFW_OPENGL_PROFILE, GLFW_OPENGL_CORE_PROFILE);
|
||||
#if not defined(__APPLE__)
|
||||
glfwOpenWindowHint(GLFW_OPENGL_VERSION_MAJOR, 4);
|
||||
#ifdef OPENSUBDIV_HAS_GLSL_COMPUTE
|
||||
glfwOpenWindowHint(GLFW_OPENGL_VERSION_MINOR, 3);
|
||||
#else
|
||||
glfwOpenWindowHint(GLFW_OPENGL_VERSION_MINOR, 2);
|
||||
#endif
|
||||
|
||||
#else
|
||||
glfwOpenWindowHint(GLFW_OPENGL_VERSION_MAJOR, 3);
|
||||
glfwOpenWindowHint(GLFW_OPENGL_VERSION_MINOR, 2);
|
||||
#endif
|
||||
glfwOpenWindowHint(GLFW_OPENGL_VERSION_MAJOR, major);
|
||||
glfwOpenWindowHint(GLFW_OPENGL_VERSION_MINOR, minor);
|
||||
|
||||
glfwOpenWindowHint(GLFW_OPENGL_FORWARD_COMPAT, GL_TRUE);
|
||||
}
|
||||
|
||||
@ -1815,15 +1827,20 @@ int main(int argc, char ** argv) {
|
||||
for (int i = 1; i < argc; ++i) {
|
||||
if (strstr(argv[i], ".obj")) {
|
||||
animobjs.push_back(argv[i]);
|
||||
} else if (!strcmp(argv[i], "-axis")) {
|
||||
}
|
||||
else if (!strcmp(argv[i], "-axis")) {
|
||||
g_axis = false;
|
||||
} else if (!strcmp(argv[i], "-d")) {
|
||||
}
|
||||
else if (!strcmp(argv[i], "-d")) {
|
||||
g_level = atoi(argv[++i]);
|
||||
} else if (!strcmp(argv[i], "-c")) {
|
||||
}
|
||||
else if (!strcmp(argv[i], "-c")) {
|
||||
g_repeatCount = atoi(argv[++i]);
|
||||
} else if (!strcmp(argv[i], "-f")) {
|
||||
}
|
||||
else if (!strcmp(argv[i], "-f")) {
|
||||
fullscreen = true;
|
||||
} else {
|
||||
}
|
||||
else {
|
||||
std::ifstream ifs(argv[1]);
|
||||
if (ifs) {
|
||||
std::stringstream ss;
|
||||
@ -1858,7 +1875,7 @@ int main(int argc, char ** argv) {
|
||||
|
||||
#define CORE_PROFILE
|
||||
#ifdef CORE_PROFILE
|
||||
setGLCoreProfile();
|
||||
setGLCoreProfile(4, 4);
|
||||
#endif
|
||||
|
||||
if (fullscreen) {
|
||||
@ -1868,7 +1885,7 @@ int main(int argc, char ** argv) {
|
||||
// apparently glfwGetPrimaryMonitor fails under linux : if no primary,
|
||||
// settle for the first one in the list
|
||||
if (not g_primary) {
|
||||
int count=0;
|
||||
int count = 0;
|
||||
GLFWmonitor ** monitors = glfwGetMonitors(&count);
|
||||
|
||||
if (count)
|
||||
@ -1882,12 +1899,28 @@ int main(int argc, char ** argv) {
|
||||
}
|
||||
}
|
||||
|
||||
if (not (g_window=glfwCreateWindow(g_width, g_height, windowTitle,
|
||||
fullscreen and g_primary ? g_primary : NULL, NULL))) {
|
||||
printf("Failed to open window.\n");
|
||||
g_window = glfwCreateWindow(g_width, g_height, windowTitle,
|
||||
fullscreen and g_primary ? g_primary : NULL, NULL);
|
||||
|
||||
#ifdef CORE_PROFILE
|
||||
if (not g_window){
|
||||
setGLCoreProfile(4, 2);
|
||||
g_window = glfwCreateWindow(g_width, g_height, windowTitle,
|
||||
fullscreen and g_primary ? g_primary : NULL, NULL);
|
||||
}
|
||||
if (not g_window){
|
||||
setGLCoreProfile(3, 3);
|
||||
g_window = glfwCreateWindow(g_width, g_height, windowTitle,
|
||||
fullscreen and g_primary ? g_primary : NULL, NULL);
|
||||
}
|
||||
|
||||
#endif
|
||||
if (not g_window){
|
||||
glfwTerminate();
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
glfwMakeContextCurrent(g_window);
|
||||
|
||||
// accommocate high DPI displays (e.g. mac retina displays)
|
||||
|
@ -100,8 +100,8 @@ public:
|
||||
_weights[i] = 1.0;
|
||||
}
|
||||
|
||||
_size = (int)_sources.size();
|
||||
_lastOffset = (int)_sources.size() - 1;
|
||||
_size = static_cast<int>(_sources.size());
|
||||
_lastOffset = _size - 1;
|
||||
}
|
||||
|
||||
template <class W, class WACCUM>
|
||||
@ -260,11 +260,11 @@ private:
|
||||
_sizes.resize(dst+1);
|
||||
}
|
||||
// Initialize the new stencil's meta-data (offset, size).
|
||||
_indices[dst] = (int)_sources.size();
|
||||
_indices[dst] = static_cast<int>(_sources.size());
|
||||
_sizes[dst] = 0;
|
||||
// Keep track of where the current stencil begins, which lets us
|
||||
// avoid having to look it up later.
|
||||
_lastOffset = (int)_sources.size();
|
||||
_lastOffset = static_cast<int>(_sources.size());
|
||||
}
|
||||
// Cache the number of elements as an optimization, it's faster than
|
||||
// calling size() on any of the vectors.
|
||||
|
Loading…
Reference in New Issue
Block a user