PACKAGES MAY BE USED

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的更多相关文章

  1. Github上的1000多本免费电子书重磅来袭!

    Github上的1000多本免费电子书重磅来袭!   以前 StackOverFlow 也给出了一个免费电子书列表,现在在Github上可以看到时刻保持更新的列表了. 瞥一眼下面的书籍分类目录,你就能 ...

  2. Github 的一个免费编程书籍列表

    Index Ada Agda Alef Android APL Arduino ASP.NET MVC Assembly Language Non-X86 AutoHotkey Autotools A ...

  3. 【机器学习Machine Learning】资料大全

    昨天总结了深度学习的资料,今天把机器学习的资料也总结一下(友情提示:有些网站需要"科学上网"^_^) 推荐几本好书: 1.Pattern Recognition and Machi ...

  4. 1.openGL 初探

    GLEW, GLFW和GLM介绍 现在你有了工程,就让我们开始介绍下工程所用到的开源库和为啥需要这些. The OpenGL Extension Wrangler (GLEW)是用来访问OpenGL ...

  5. openGL实现二维图形和三维图形

    openGL是一个强大的底层图形库,其命令最初的时候使用C语言实现的.openGL定义了一个图形程序接口,常用于制作处理三维图像,功能强大,调用方便,在图像处理十分受欢迎. 实现图形主要使用的是ope ...

  6. Machine and Deep Learning with Python

    Machine and Deep Learning with Python Education Tutorials and courses Supervised learning superstiti ...

  7. OpenGL 开始学习指南

    近期需要做一个涌潮的预报与仿真模拟,为了使模型更具有真实感,且逼真,使用起来更灵活.感觉还是得从基础的OpenGL学习.鉴于Direct3D技术存在的众多不确定性,且评论不太好的原因,决定用OpenG ...

  8. OpenGL ES应用开发实践指南:iOS卷

    <OpenGL ES应用开发实践指南:iOS卷> 基本信息 原书名:Learning OpenGL ES for iOS:A Hands-On Guide to Modern 3D Gra ...

  9. 机器学习(Machine Learning)&深度学习(Deep Learning)资料【转】

    转自:机器学习(Machine Learning)&深度学习(Deep Learning)资料 <Brief History of Machine Learning> 介绍:这是一 ...

随机推荐

  1. 菜鸟学IT之python网页爬取多页爬取

    作业来源:https://edu.cnblogs.com/campus/gzcc/GZCC-16SE1/homework/3002 0.从新闻url获取点击次数,并整理成函数 newsUrl news ...

  2. Python----多项式回归

    多项式线性回归 1.多项式线性方程: 与多元线性回归相比,它只有一个自变量,但有不同次方数. 2.举例: import numpy as np import matplotlib.pyplot as ...

  3. 踩坑之mongodb配置文件修改

    一.说明 本文档是在mongodb为3.4下编写的,仅作为参考 配置mongodb有两种方式,一种是通过mongod和mongos两个命令:另外一种方式就是配置文件的方式.因为更容易去管理,所以后者更 ...

  4. 剑指Offer面试题 二维数组中的查找

    题目链接:https://www.nowcoder.com/questionTerminal/abc3fe2ce8e146608e868a70efebf62e 题目大意: 略 分析: 对萌醒很开拓思维 ...

  5. flask 利用flask_wtf扩展 创建web表单

    在Flask中,为了处理web表单,我们一般使用Flask-WTF扩展,它封装了WTForms,并且它有验证表单数据的功能 创建语句格式: startTime = DateTimeField('计划开 ...

  6. Add AI feature to Xamarin.Forms app

    Now, AI is one of important technologies.Almost all platforms have API sets of AI. Following list is ...

  7. anaconda相关使用方法

    本文不涉及anaconda的安装,如果需要请自行搜索,cnblogs和CSDN都挺多的. conda安装完,大部分人都jupyter notebook的使用需求,jupyter的开启命令是什么呢? j ...

  8. [BZOJ 1095] [ZJOI 2007] 捉迷藏

    Description 传送门 Solution 先将原树转化成点分树: 然后维护三个堆: \(c[i]\) 保存点分树中子树 \(i\) 中的黑色节点到 \(fa[i]\) 的距离: \(b[i]\ ...

  9. 【BZOJ4032】[HEOI2015]最短不公共子串(后缀自动机,序列自动机)

    [BZOJ4032][HEOI2015]最短不公共子串(后缀自动机,序列自动机) 题面 BZOJ 洛谷 题解 数据范围很小,直接暴力构建后缀自动机和序列自动机,然后直接在两个自动机上进行\(bfs\) ...

  10. DBCP 连接池

    DBCP数据源 DBCP 是 Apache 软件基金组织下的开源连接池实现 导入maven包: <!-- dbcp连接池 --> <dependency> <groupI ...