openGL learning
PACKAGES MAY BE USED
- GL3W - For modern OpenGL methods
- GLFW - Window creation and management
- GLM - Maths calculations
- stb_image - Image loading
- TinyOBJLoader - Obj loading
- TinyEXR - EXR file saving
- ImGui - UI rendering
- tinyfiledialogs - Call native file dialog (require Zenity on linux)
DENOISE:
https://github.com/OpenImageDenoise/oidn
LINUX PLATFORM
cmake_minimum_required(VERSION 2.8)
project(CP_01) set(GLFW_HOME /home/gearslogy/Plugin_dev/opengl/GLEXT)
include_directories(${GLFW_HOME}/include/)
link_directories(${GLFW_HOME}/lib/) find_package(OpenGL REQUIRED)
include_directories(${OpenGL_INCLUDE_DIRS})
link_directories(${OpenGL_LIBRARY_DIRS})
add_definitions(${OpenGL_DEFINITIONS})
if(NOT OPENGL_FOUND)
message(ERROR " OPENGL not found!")
endif(NOT OPENGL_FOUND) add_executable(CP_01 main.cpp)
target_link_libraries(CP_01 glfw GLEW)
//
// Created by gearslogy on 11/1/18.
// #include <GL/glew.h>
#include <GL/gl.h>
#include <GLFW/glfw3.h> enum VAO_IDs {Triangles ,NumVAOs};
enum Buffer_IDs{ArrayBuffer,NumBuffers};
enum Attrib_IDS{vPosition=}; GLuint VAOs[NumVAOs];
GLuint Buffers[NumBuffers]; const GLuint NumVertices = ; void init(void){ static const GLfloat vertices[NumVertices][] = {
{-0.90f, -0.90f},
{0.85f, -0.90f},
{-0.90f, 0.85f}, {0.90f, -0.85f},
{0.90f, 0.90f},
{-0.85f, 0.90f},
}; glCreateBuffers(NumBuffers,Buffers);
glNamedBufferStorage(Buffers[ArrayBuffer],sizeof(vertices),vertices,); glGenVertexArrays(NumVAOs,VAOs);
glBindVertexArray(VAOs[Triangles]);
glBindBuffer(GL_ARRAY_BUFFER,Buffers[ArrayBuffer]);
glVertexAttribPointer(vPosition,,GL_FLOAT,GL_FALSE,,);
glEnableVertexAttribArray(vPosition); } void display(void){
static const float black[] = {0.0f,0.0f,0.0f,0.0f};
glClearBufferfv(GL_COLOR,,black);
glBindVertexArray(VAOs[Triangles]);
glDrawArrays(GL_TRIANGLES, ,NumVertices);
} int main(){
glfwInit(); GLFWwindow *window =glfwCreateWindow(,,"Triangles",NULL,NULL);
glfwMakeContextCurrent(window);
glewInit();
init(); while(!glfwWindowShouldClose(window)){
display();
glfwSwapBuffers(window);
glfwPollEvents();
} glfwDestroyWindow(window);
glfwTerminate();
}

WINDOWS PLATFORM,VC2019, 全部静态链接
Windows CMakelists:
cmake_minimum_required(VERSION 3.5) project(Triangle) set(CMAKE_CXX_STANDARD )
set(CMAKE_CXX_STANDARD_REQUIRED ON)
# OPENGL
find_package(OpenGL REQUIRED)
include_directories(${OpenGL_INCLUDE_DIRS})
link_directories(${OpenGL_LIBRARY_DIRS})
add_definitions(${OpenGL_DEFINITIONS}) if(NOT OPENGL_FOUND)
message(ERROR " OPENGL not found!")
endif(NOT OPENGL_FOUND) # GLEW
set(GLEW_HOME D:/plugin_dev/libs/glew-2.1.)
include_directories(${GLEW_HOME}/include)
link_directories(${GLEW_HOME}/lib/Release/x64) # GLFW
set(GLFW_HOME D:/plugin_dev/libs/glfw-3.3..bin.WIN64)
include_directories(${GLFW_HOME}/include/)
link_directories(${GLFW_HOME}/lib-vc2019) add_executable(Triangle main.cpp)
target_link_libraries(Triangle glew32s glfw3 opengl32)
在win32平台一定要显式的写出opengl32链接库。原因来自:这里
统统设置STATIC
#define GLEW_STATIC
// GLEW #include <GL/glew.h>
#include <cstdlib>
#undef GLFW_DLL
// GLFW
#include <GLFW/glfw3.h>
2,simple vertex shader & fragment shader

trangles.vert:
#version core layout (location =) in vec4 vPosition;
void main()
{
gl_Position = vec4(vPosition.x, vPosition.y, vPosition.z, 1.0);
}
trangles.frag:
#version core
layout (location =) out vec4 FragColor;
void main(){ FragColor = vec4(,,,1.0);
}
loadshader.h
//
// Created by gearslogy on 11/2/18.
// #ifndef CP_01_LOADSHADER_H
#define CP_01_LOADSHADER_H #include <string>
#include <iostream>
#include <fstream>
#include <GL/glew.h>
#include <GLFW/glfw3.h>
#include <vector>
#include <algorithm> using namespace std;
class FileIO
{
public:
static string load(const char *path){
ifstream in;
in.open(path,ios::in);
if(!in.is_open())
cout << "read " << path << " error\n"; string temp; string line;
while(getline(in,line)){
temp += line;
temp += "\n";
} in.close();
return temp;
}
}; void ApplyShaders(GLuint &shaderProgram,
const vector<string> &codes,
const vector<GLenum> shaderTypes )
{
if(codes.size()!=shaderTypes.size())
{
cout << "shader src size not match type size\n";
return ;
} // FOR LOG
int success;
char infoLog[]; vector <GLuint> shaders;
for(int i=;i<codes.size();i++){
GLuint shader = glCreateShader(shaderTypes[i]);
cout << "Shader ID :" << shader <<endl;
const char *code = codes[i].c_str();
glShaderSource(shader, , &code, NULL);
glCompileShader(shader);
// check compile error
glGetShaderiv(shader, GL_COMPILE_STATUS, &success);
if (!success)
{
glGetShaderInfoLog(shader, , NULL, infoLog);
std::cout << "ERROR::COMPILATION_FAILED\n" << infoLog << std::endl;
}
glAttachShader(shaderProgram, shader);
// append shader to vector to delete later
} glLinkProgram(shaderProgram);
// check for linking errors
glGetProgramiv(shaderProgram, GL_LINK_STATUS, &success);
if (!success) {
glGetProgramInfoLog(shaderProgram, , NULL, infoLog);
std::cout << "ERROR::SHADER::PROGRAM::LINKING_FAILED\n" << infoLog << std::endl;
} //glDeleteShader(vertexShader);
//glDeleteShader(fragmentShader); glUseProgram(shaderProgram);
for(int i=;i<shaders.size();i++)
glDeleteShader(shaders[i]); } #endif //CP_01_LOADSHADER_H
main.cpp:
#include <GL/glew.h>
#include <GL/gl.h> #include <GLFW/glfw3.h>
#include <iostream>
#include "loadshader.h"
#define BUFFER_OFFSET(offset) ((void *)(offset)) using namespace std;
enum VAO_IDs {Triangles ,NumVAOs}; // NumVAOs 1
enum Buffer_IDs{ArrayBuffer,NumBuffers};
enum Attrib_IDS{vPosition=}; GLuint VAOs[NumVAOs];
GLuint Buffers[NumBuffers]; const GLuint NumVertices = ; void init(void){ static const GLfloat vertices[NumVertices][] = {
{-0.90f, -0.90f},
{0.85f, -0.90f},
{-0.90f, 0.85f}, {0.90f, -0.85f},
{0.90f, 0.90f},
{-0.85f, 0.90f},
};
glCreateVertexArrays(NumVAOs,VAOs);//glGenVertexArrays(NumVAOs,VAOs);
cout << "CreateVertexArrays VAOs[0]: "<<VAOs[] << endl; glCreateBuffers(NumBuffers,Buffers);
cout << "CreateVertexArrays Buffers[0]: "<<Buffers[] << endl; glNamedBufferStorage(Buffers[ArrayBuffer],sizeof(vertices),vertices,); const char *vertexShaderSource = FileIO::load("../triangles.vert").c_str();
const char *fragmentShaderSource = FileIO::load("../triangles.frag").c_str(); unsigned int vertexShader;
vertexShader = glCreateShader(GL_VERTEX_SHADER);
glShaderSource(vertexShader, , &vertexShaderSource, NULL);
glCompileShader(vertexShader); int success;
char infoLog[];
glGetShaderiv(vertexShader, GL_COMPILE_STATUS, &success);
if (!success)
{
glGetShaderInfoLog(vertexShader, , NULL, infoLog);
std::cout << "ERROR::SHADER::VERTEX::COMPILATION_FAILED\n" << infoLog << std::endl;
} unsigned int fragmentShader;
fragmentShader = glCreateShader(GL_FRAGMENT_SHADER);
glShaderSource(fragmentShader, , &fragmentShaderSource, NULL);
glCompileShader(fragmentShader);
glGetShaderiv(fragmentShader, GL_COMPILE_STATUS, &success);
if (!success)
{
glGetShaderInfoLog(fragmentShader, , NULL, infoLog);
std::cout << "ERROR::SHADER::FRAGMENT::COMPILATION_FAILED\n" << infoLog << std::endl;
} unsigned int shaderProgram;
shaderProgram = glCreateProgram();
glAttachShader(shaderProgram, vertexShader);
glAttachShader(shaderProgram, fragmentShader);
glLinkProgram(shaderProgram); // check for linking errors
glGetProgramiv(shaderProgram, GL_LINK_STATUS, &success);
if (!success) {
glGetProgramInfoLog(shaderProgram, , NULL, infoLog);
std::cout << "ERROR::SHADER::PROGRAM::LINKING_FAILED\n" << infoLog << std::endl;
} glUseProgram(shaderProgram);
glDeleteShader(vertexShader);
glDeleteShader(fragmentShader); glBindVertexArray(VAOs[Triangles]);
glBindBuffer(GL_ARRAY_BUFFER,Buffers[ArrayBuffer]);
glVertexAttribPointer(,,GL_FLOAT,GL_FALSE, * sizeof(float),BUFFER_OFFSET());
glEnableVertexAttribArray(); } void display(void){
static const float black[] = {0.0f,0.5f,0.0f,0.0f};
glClearBufferfv(GL_COLOR,,black);
glBindVertexArray(VAOs[Triangles]);
glDrawArrays(GL_TRIANGLES, ,NumVertices); } int main(){
glfwInit(); GLFWwindow *window =glfwCreateWindow(,,"Triangles",NULL,NULL);
glfwMakeContextCurrent(window);
glewInit();
init(); while(!glfwWindowShouldClose(window)){
display();
glfwSwapBuffers(window);
glfwPollEvents();
} glfwDestroyWindow(window);
glfwTerminate();
}
replace main.cpp shader's methods then use the loadshader.h ApplyShaders:
main.cpp:
//
// Created by gearslogy on 11/1/18.
// #include <GL/glew.h>
#include <GL/gl.h> #include <GLFW/glfw3.h>
#include <iostream>
#include "loadshader.h"
#define BUFFER_OFFSET(offset) ((void *)(offset)) using namespace std;
enum VAO_IDs {Triangles ,NumVAOs}; // NumVAOs 1
enum Buffer_IDs{ArrayBuffer,NumBuffers};
enum Attrib_IDS{vPosition=}; GLuint VAOs[NumVAOs];
GLuint Buffers[NumBuffers]; const GLuint NumVertices = ; void init(void){ static const GLfloat vertices[NumVertices][] = {
{-0.90f, -0.90f},
{0.85f, -0.90f},
{-0.90f, 0.85f}, {0.90f, -0.85f},
{0.90f, 0.90f},
{-0.85f, 0.90f},
};
glCreateVertexArrays(NumVAOs,VAOs);//glGenVertexArrays(NumVAOs,VAOs);
cout << "CreateVertexArrays VAOs[0]: "<<VAOs[] << endl; glCreateBuffers(NumBuffers,Buffers);
cout << "CreateVertexArrays Buffers[0]: "<<Buffers[] << endl; glNamedBufferStorage(Buffers[ArrayBuffer],sizeof(vertices),vertices,); vector <string> codes;
vector <GLenum> shaderTypes;
codes.push_back(FileIO::load("../triangles.vert"));
codes.push_back(FileIO::load("../triangles.frag"));
shaderTypes.push_back(GL_VERTEX_SHADER);
shaderTypes.push_back(GL_FRAGMENT_SHADER); GLuint shaderProgram = glCreateProgram();
ApplyShaders(shaderProgram,codes,shaderTypes); glBindVertexArray(VAOs[Triangles]);
glBindBuffer(GL_ARRAY_BUFFER,Buffers[ArrayBuffer]);
glVertexAttribPointer(,,GL_FLOAT,GL_FALSE, * sizeof(float),BUFFER_OFFSET());
glEnableVertexAttribArray(); } void display(void){
static const float black[] = {0.0f,0.5f,0.0f,0.0f};
glClearBufferfv(GL_COLOR,,black);
glBindVertexArray(VAOs[Triangles]);
glDrawArrays(GL_TRIANGLES, ,NumVertices); } int main(){
glfwInit(); GLFWwindow *window =glfwCreateWindow(,,"Triangles",NULL,NULL);
glfwMakeContextCurrent(window);
glewInit();
init(); while(!glfwWindowShouldClose(window)){
display();
glfwSwapBuffers(window);
glfwPollEvents();
} glfwDestroyWindow(window);
glfwTerminate();
}
openGL learning的更多相关文章
- Github上的1000多本免费电子书重磅来袭!
Github上的1000多本免费电子书重磅来袭! 以前 StackOverFlow 也给出了一个免费电子书列表,现在在Github上可以看到时刻保持更新的列表了. 瞥一眼下面的书籍分类目录,你就能 ...
- Github 的一个免费编程书籍列表
Index Ada Agda Alef Android APL Arduino ASP.NET MVC Assembly Language Non-X86 AutoHotkey Autotools A ...
- 【机器学习Machine Learning】资料大全
昨天总结了深度学习的资料,今天把机器学习的资料也总结一下(友情提示:有些网站需要"科学上网"^_^) 推荐几本好书: 1.Pattern Recognition and Machi ...
- 1.openGL 初探
GLEW, GLFW和GLM介绍 现在你有了工程,就让我们开始介绍下工程所用到的开源库和为啥需要这些. The OpenGL Extension Wrangler (GLEW)是用来访问OpenGL ...
- openGL实现二维图形和三维图形
openGL是一个强大的底层图形库,其命令最初的时候使用C语言实现的.openGL定义了一个图形程序接口,常用于制作处理三维图像,功能强大,调用方便,在图像处理十分受欢迎. 实现图形主要使用的是ope ...
- Machine and Deep Learning with Python
Machine and Deep Learning with Python Education Tutorials and courses Supervised learning superstiti ...
- OpenGL 开始学习指南
近期需要做一个涌潮的预报与仿真模拟,为了使模型更具有真实感,且逼真,使用起来更灵活.感觉还是得从基础的OpenGL学习.鉴于Direct3D技术存在的众多不确定性,且评论不太好的原因,决定用OpenG ...
- OpenGL ES应用开发实践指南:iOS卷
<OpenGL ES应用开发实践指南:iOS卷> 基本信息 原书名:Learning OpenGL ES for iOS:A Hands-On Guide to Modern 3D Gra ...
- 机器学习(Machine Learning)&深度学习(Deep Learning)资料【转】
转自:机器学习(Machine Learning)&深度学习(Deep Learning)资料 <Brief History of Machine Learning> 介绍:这是一 ...
随机推荐
- 解决hash冲突的方法
复制粘贴于:https://www.cnblogs.com/wuchaodzxx/p/7396599.html#H1_2 开放地址法(线性探测法.二次探测.伪随机探测) 再哈希法 链地址法 建立公共溢 ...
- Asp.Net Core Options模式的知识总结
Options模式是Asp.Net Core中用于配置的一种模式,它利用了系统的依赖注入,并且还可以利用配置系统.它使我们可以采用依赖注入的方法直接使用绑定的一个POCO对象,这个POCO对象就叫做O ...
- Spring MVC 使用介绍(十六)数据验证 (三)分组、自定义、跨参数、其他
一.概述 除了依赖注入.方法参数,Bean Validation 1.1定义的功能还包括: 1.分组验证 2.自定义验证规则 3.类级别验证 4.跨参数验证 5.组合多个验证注解 6.其他 二.分组验 ...
- Git 操作命令
一.Git 基本配置 1.配置 命令:git config --global prop_name prop_value 如配置git用户名与邮箱: git config --global user. ...
- 关于ES6
一.变量声明const和let 变量提升:在ES6之前,我们都是用var关键字声明变量.无论声明在何处,都会被视为声明在函数的最顶部(不在函数内即在全局作用域的最顶部).这就是函数变量提升例如: fu ...
- 搭建Linux下的SVN服务器
______________________________________________配置SVN步骤______________________________________________ ...
- My Todo-List
有些事情要明着写出来才会去干. 这里是一个不断更新的Todo-List,大致按照重要度和列出时间排序. 主要着眼短期计划,其中的大部分事务应该在一周内解决,争取不做一只鸽子. 填好模板库的坑. 学习树 ...
- (转)Java回收对象的标记 和 对象的二次标记过程
Java回收对象的标记 和 对象的二次标记过程 二次标记 针对这个问题,虚拟机的做法是进行两次标记,即第一次标记不在“关系网”中的对象.第二次的话就要先判断该对象有没有实现finalize()方法了, ...
- Qt: usb热插拔检测(windows);
Qt提供了QAbstractNativeEventFilter来实现本地时间得过滤,通过对本地事件的检测,判断usb热插拔:(这里是windows 的例子); 首先,以QWidget, QAbstra ...
- hadoop记录-hive常见设置
分区表 set hive.exec.dynamic.partition=true; set hive.exec.dynamic.partition.mode=nonstrict;create tabl ...