1
0
Fork 0

Add Textures

This commit is contained in:
MrDev023 2016-09-29 21:31:44 +02:00
parent 78dc21fee8
commit 94a63390ef
19 changed files with 8232 additions and 29 deletions

14
clean.bat Normal file
View file

@ -0,0 +1,14 @@
rm -rf bin
rm -rf CMakeFiles
rm -f CMakeCache.txt
rm -f cmake_install.cmake
rm -f Makefile
rm -f *.vcxproj*
rm -f *.sln
rm -f *.db
rm -rf .vs

BIN
res/images/2x2_grid.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 54 KiB

BIN
res/images/pearl-0003.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.4 MiB

View file

@ -1,6 +1,7 @@
uniform float a; #version 150
uniform float y;
void main(void){ void main(void){
if(a >= 0)gl_FragColor = vec4(a,0,0,1); gl_FragColor= vec4(1, 1 - abs(y)/50,1 - abs(y)/50,1);
else gl_FragColor = vec4(0,-a,0,1);
} }

View file

@ -1,4 +1,4 @@
#version 150
void main(void){ void main(void){
gl_FrontColor = gl_Color; gl_FrontColor = gl_Color;

View file

@ -10,11 +10,25 @@
#include <sndfile.h> #include <sndfile.h>
#include <vector> #include <vector>
/*
Class created by MrDev023
*/
class Audio{ class Audio{
public: public:
/*
Initialise le Device pour lire des pistes audio
*/
static void initOpenAL(); static void initOpenAL();
/*
Permet de detruire le device
*/
static void destroyOpenAL(); static void destroyOpenAL();
/*
Fonction permettant de lire un son puis de retourner l identifiant de la source
*/
static ALuint loadSound(std::string); static ALuint loadSound(std::string);
static ALuint createSource(ALuint*); static ALuint createSource(ALuint*);
static ALuint createSource(const std::string); static ALuint createSource(const std::string);

11
src/image.cpp Normal file
View file

@ -0,0 +1,11 @@
#include "renderer.h"
Image::Image(unsigned char* data,int width,int height){
this->data = data;
this->width = width;
this->height = height;
}
Image::~Image(){
delete this->data;
}

6224
src/lodepng.cpp Normal file

File diff suppressed because it is too large Load diff

1760
src/lodepng.h Normal file

File diff suppressed because it is too large Load diff

View file

@ -2,39 +2,44 @@
#include "audio.h" #include "audio.h"
#include "renderer.h" #include "renderer.h"
#include <iostream>
#include <fstream>
void event(SDL_Event e){ void event(SDL_Event e){
switch( e.type ){
case SDL_KEYDOWN:
switch( e.key.keysym.sym ){
} }
break;
case SDL_KEYUP:
switch( e.key.keysym.sym ){
}
break;
}
}
int main(int argc, char** argv){ int main(int argc, char** argv){
Window::initWindow(800,600,"Test"); Window::initWindow(800,800,"Title");
Audio::initOpenAL(); //Texture* t = Texture::createTexture("res/images/2x2_grid.png");
GLuint s = Shader::createShader("test.vert","test.frag"); Texture* t = Texture::createTexture("res/images/pearl-0003.png");
float i = 0; while(!Window::closeRequested){
Shader::bindShader(&s); Window::pollEvent(event);
while(!Window::closeRequested){//main loop
Shader::setUniform(&s,"a",cos(i));
Window::pollEvent(&event);
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
Texture::bindTexture(t->id);
glLoadIdentity();
glBegin(GL_QUADS); glBegin(GL_QUADS);
glVertex2f(-1,-1); glColor3f(1,1,1);
glVertex2f(-1,1); glTexCoord2f(0,0);
glVertex2f(1,1); glVertex2i(-1,-1);
glVertex2f(1,-1); glTexCoord2f(0,t->ratioY);
glVertex2i(-1,1);
glTexCoord2f(t->ratioX,t->ratioY);
glVertex2i(1,1);
glTexCoord2f(t->ratioX,0);
glVertex2i(1,-1);
glEnd(); glEnd();
Window::displayUpdate(); Window::displayUpdate();
i+=1/5000.0f;
} }
Shader::destroyShader(&s); delete t;
Audio::destroyOpenAL();
Window::destroyWindow(); Window::destroyWindow();
return 0; return 0;
} }

View file

@ -5,6 +5,8 @@
#include <cstddef> #include <cstddef>
#include <algorithm> #include <algorithm>
#define byte char
extern const float PI; extern const float PI;
float lerp(float,float,float); float lerp(float,float,float);
float cLerp(float,float,float); float cLerp(float,float,float);

2
src/physics.cpp Normal file
View file

@ -0,0 +1,2 @@
#include "physics.h"

6
src/physics.h Normal file
View file

@ -0,0 +1,6 @@
#ifndef PHYSICS_H
#define PHYSICS_H
#endif

View file

@ -13,6 +13,8 @@
#include <sys/stat.h> #include <sys/stat.h>
#include <algorithm> #include <algorithm>
#include "lodepng.h"
#include <SDL2/SDL.h> #include <SDL2/SDL.h>
#include <GL/glew.h> #include <GL/glew.h>
#include <GL/gl.h> #include <GL/gl.h>
@ -20,6 +22,38 @@
bool fileExists(const std::string&); bool fileExists(const std::string&);
class Shader;
class Texture;
class Image;
class Image{
public:
unsigned char* data;
int width;
int height;
Image(unsigned char*,int,int);
~Image();
};
class Texture{
public:
static Texture* createTexture(const char*);
static void destroyTexture(GLuint*);
static void bindTexture(GLuint*);
static void unbindTexture();
double ratioX;
double ratioY;
GLuint* id;
Texture(GLuint,double,double);
~Texture();
private:
static Image* loadTexture(const char*);
};
class Shader{ class Shader{
public: public:
static std::string LoadSource(const char*); static std::string LoadSource(const char*);

View file

@ -128,6 +128,8 @@ GLuint Shader::createShader(const char* vertName,const char* fragName){
glValidateProgram(program); glValidateProgram(program);
glDeleteShader(vertShader); glDeleteShader(vertShader);
glDeleteShader(fragShader); glDeleteShader(fragShader);
printf("Vertex Shader '%s' loaded !\n",vertName);
printf("Fragment Shader '%s' loaded !\n",fragName);
return program; return program;
} }

90
src/texture.cpp Normal file
View file

@ -0,0 +1,90 @@
#include "renderer.h"
Texture::Texture(GLuint id,double u3,double v3){
this->id = new GLuint(id);
this->ratioX = u3;
this->ratioY = v3;
}
Texture::~Texture(){
Texture::destroyTexture(this->id);
delete this->id;
}
Texture* Texture::createTexture(const char* file){
Image* img = Texture::loadTexture(file);
if(img == NULL)return NULL;
GLuint t;
glGenTextures(1, &t);
glBindTexture(GL_TEXTURE_2D, t);
// Texture size must be power of two for the primitive OpenGL version this is written for. Find next power of two.
size_t u2 = 1; while(u2 < img->width) u2 *= 2;
size_t v2 = 1; while(v2 < img->height) v2 *= 2;
// Ratio for power of two version compared to actual version, to render the non power of two image with proper size.
double u3 = (double)img->width / u2;
double v3 = (double)img->height / v2;
// Make power of two version of the image.
std::vector<unsigned char> image2(u2 * v2 * 4 * (img->width/48));
for(size_t y = 0; y < img->height; y++)
for(size_t x = 0; x < img->width; x++)
for(size_t c = 0; c < 4; c++)
{
image2[4 * u2 * y + 4 * x + c] = img->data[4 * img->width * y + 4 * x + c];
}
// Enable the texture for OpenGL.
glEnable(GL_TEXTURE_2D);
glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST); //GL_NEAREST = no smoothing
glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, u2, v2, 0, GL_RGBA, GL_UNSIGNED_BYTE, &image2[0]);
std::cout << "GL Texture created (" << file << ":" << img->width << "x" << img->height << ") #" << t << " !" << std::endl;
image2.clear();
delete img;
return new Texture(t,u3,v3);
}
void Texture::bindTexture(GLuint* texture){
glDisable(GL_CULL_FACE);
glDisable(GL_DEPTH_TEST);
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
glEnable(GL_BLEND);
glDisable(GL_ALPHA_TEST);
glEnable(GL_TEXTURE_2D);
glBindTexture(GL_TEXTURE_2D,*texture);
}
void Texture::unbindTexture(){
glDisable(GL_TEXTURE_2D);
glBindTexture(GL_TEXTURE_2D,0);
}
void Texture::destroyTexture(GLuint* texture){
glDeleteTextures(1,texture);
}
Image* Texture::loadTexture(const char* file){
std::vector<unsigned char> image; //the raw pixels
unsigned width, height;
//decode
unsigned error = lodepng::decode(image, width, height, file);
//if there's an error, display it
if(error){
std::cout << "decoder error " << error << ": " << lodepng_error_text(error) << std::endl;
return NULL;
}
//the pixels are now in the vector "image", 4 bytes per pixel, ordered RGBARGBA..., use it as texture, draw it, ...
std::cout << "Image loaded (" << file << ") ! : " << width << "x" << height << " with " << image.size() << " byte of data." << std::endl;
unsigned char* p = (unsigned char*)malloc(sizeof(unsigned char) * image.size());
for(int i = 0;i < image.size();i++)p[i] = image[i];
image.clear();
return new Image(p,width,height);
}

View file

@ -5,6 +5,10 @@ SDL_Event Window::event;
SDL_GLContext Window::context; SDL_GLContext Window::context;
bool Window::closeRequested = false; bool Window::closeRequested = false;
unsigned long deltaTime = 0;
unsigned long updateTime = 0;
std::string Window::title;
void Window::initWindow(int width,int height,std::string title){ void Window::initWindow(int width,int height,std::string title){
/* Initialisation simple */ /* Initialisation simple */
@ -18,6 +22,9 @@ void Window::initWindow(int width,int height,std::string title){
width, width,
height, height,
SDL_WINDOW_SHOWN | SDL_WINDOW_OPENGL); SDL_WINDOW_SHOWN | SDL_WINDOW_OPENGL);
Window::title = title.c_str();
if(!Window::pWindow){ if(!Window::pWindow){
fprintf(stderr,"Erreur de création de la fenêtre: %s\n",SDL_GetError()); fprintf(stderr,"Erreur de création de la fenêtre: %s\n",SDL_GetError());
exit(-1); exit(-1);
@ -45,6 +52,13 @@ void Window::initWindow(int width,int height,std::string title){
} }
void Window::setTitleSuffixe(const char* t){
std::string* a = new std::string(t);
*a = title + *a;
SDL_SetWindowTitle(Window::pWindow, a->c_str());
delete a;
}
void Window::destroyWindow(){ void Window::destroyWindow(){
SDL_GL_DeleteContext ( context ) ; SDL_GL_DeleteContext ( context ) ;
SDL_DestroyWindow(pWindow); SDL_DestroyWindow(pWindow);
@ -65,3 +79,14 @@ void Window::pollEvent(void(*f)(SDL_Event)){
f(Window::event); f(Window::event);
} }
} }
unsigned long currentMillisTime(){
return std::chrono::system_clock::now().time_since_epoch() /
std::chrono::milliseconds(1);
}
unsigned long currentNanoTime(){
return std::chrono::system_clock::now().time_since_epoch() /
std::chrono::nanoseconds(1);
return 0;
}

View file

@ -9,6 +9,17 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string> #include <string>
#include <time.h>
#include <chrono>
#define NTIME currentNanoTime()
#define UTIME currentMillisTime()
extern unsigned long deltaTime;
extern unsigned long updateTime;
unsigned long currentMillisTime();
unsigned long currentNanoTime();
class Window{ class Window{
@ -17,7 +28,9 @@ class Window{
static void destroyWindow(); static void destroyWindow();
static void pollEvent(void(*f)(SDL_Event)); static void pollEvent(void(*f)(SDL_Event));
static void displayUpdate(); static void displayUpdate();
static void setTitleSuffixe(const char*);
static std::string title;
static SDL_Window* pWindow; static SDL_Window* pWindow;
static SDL_Event event; static SDL_Event event;
static bool closeRequested; static bool closeRequested;