大家好,2d引擎基于opengl(es) 3d技术,是因为这样比之前的ddraw有很多好处!

1.坐标采用浮点数,可以进行曲线移动

2.如果在ddraw的对图片进行缩放和旋转的时候,是基于点像素的操作,非常的耗费性能,而采用3d的话,做这些事情是轻而易举的工作!

3.是基于渲染一个panel,然后把贴图贴在panel,然后对panel,进行旋转平移缩放的操作!

4.2d动画是基于uv进行操作的,可以将所有的动画放在一个大的贴图中,然后不断切换uv实现的动画切换!

今天的工作环境配置:

os: win7 64bit

tool: vs2012

主要有两个内容:1.渲染方块 2.渲染贴图

由于我们是2d游戏,我们采用glOrtho 2d视图,进行视图设置,具有以下步骤:

        详解:

                  glViewport()进行窗口视图设定 比如800,600

                  glMatrixMode(GL_PROJECTION);设置模型视图

                  glOrtho设置2d视图,-400,400,说明宽是800,-300,300,高是600,-100是近裁面,100是远裁面

                  由于是采用2d视图,我想游戏窗口的每一个像素,占用一个单位,这样对坐标的好,很好计算!

                 glBegin开始绘制一个几何面片,这在opengles中不被支持的方法!

                 glVertex2f是绘制点,调用glVertex2f四次,就绘制了一个panel出来

glClear(GL_COLOR_BUFFER_BIT);

glViewport(0,0,800,600);

glMatrixMode( GL_PROJECTION );

glLoadIdentity();

glOrtho(-400,400,-300,300,-100,100);

glBegin(GL_POLYGON);

GLfloat w=100;

GLfloat h=100;

glVertex2f(-w, -h);

glVertex2f(-w, h);

glVertex2f(w, h);

glVertex2f(w, -h);

glEnd();

glFlush();

下面开始贴图

贴图使用的是开源库 FreeImage3.17.0库,下载地址为:http://sourceforge.net/projects/freeimage/files/Source%20Distribution/

                在FreeImage3.17.0中自带了一个对于OpenGL使用的类,叫做TextureManaged.h TextureManaged.cpp

               FreeImage有32位和64位的版本,这里的版本对应,不是说的你的电脑系统是32bit,还是64bit的!

               是说你的编辑器是32位的还是64位的!

               同样的设置到包含目录中,以及链接库中,还有附加依赖项中!

               渲染图片代码如下:

#include "TextureManager.h"  //注意这一句要在<glut.h>之上,否则会出错
               #include <glut.h>
               GLuint textures[1];
               //显示回调函数
               void renderScreen(void){
                  //把整个窗口清理为当前清理颜色:南瓜橙
                  glClear(GL_COLOR_BUFFER_BIT);
                  glViewport(0,0,800,600);
                  glMatrixMode( GL_PROJECTION ); 
                  glLoadIdentity();
                  glOrtho(-400,400,-300,300,-100,100);
                 TextureManager::Inst()->BindTexture(textures[0]);//在这儿进行绑定贴图
                  glBegin(GL_POLYGON);
                  GLfloat w=100;
                  GLfloat h=100;
                 glTexCoord2d(0,0);glVertex2f(-w, -h); 
                 glTexCoord2d(0,1);glVertex2f(-w, h); 
                glTexCoord2d(1,1);glVertex2f(w, h); 
                glTexCoord2d(1,0);glVertex2f(w, -h);
                glEnd();
                glFlush();
                glutSwapBuffers();
             }

void Init()
            {
                       TextureManager::Inst()->LoadTexture("./1.jpg",textures[0]);//载入贴图
                      glEnable(GL_TEXTURE_2D);//启用2d纹理
                      glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR);    // 线性滤波
                      glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR);    // 线性滤波

}

int main(int argc, char* argv[])
          {

//初始化glut
                    glutInit(&argc,argv);
                   //单缓冲区
                    glutInitDisplayMode(GLUT_SINGLE|GLUT_RGBA);
                   //创建窗口,窗口名字为WindowDemo
                   glutCreateWindow("QLGameEngine");
                   //设置窗口大小
                   glutReshapeWindow(800,600);
                   Init();
                   //设置显示回调函数 
                  glutDisplayFunc(renderScreen);
                  glutMainLoop();
                  return 0;
       }

                详解:

               1.TextureManager::Inst()->LoadTexture("./1.jpg",textures[0]);//载入贴图

               2.启用纹理以及使用纹理属性

glEnable(GL_TEXTURE_2D);//启用2d纹理
                      glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR);    // 线性滤波
                      glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR);    // 线性滤波

3.   绑定贴图

TextureManager::Inst()->BindTexture(textures[0]);//在这儿进行绑定贴图

4.  设置顶点以及uv进行渲染贴图

glBegin(GL_POLYGON);
                   GLfloat w=100;
                   GLfloat h=100;
                   glTexCoord2d(0,0);glVertex2f(-w, -h); 
                   glTexCoord2d(0,1);glVertex2f(-w, h); 
                   glTexCoord2d(1,1);glVertex2f(w, h); 
                   glTexCoord2d(1,0);glVertex2f(w, -h);
                   glEnd();

运行结果:

                    一只可爱的小乌龟,显示出来了,呵呵!

                   我遇到两个问题需要解决:

                   1.就是乌龟的颜色发生变色了,原图是这样的

                   

                   2.我在Debug目录下,直接启动生成的exe,可以看到小乌龟图片,但是在VS中直接运行就看不到图片,我设置了工作目录为

                      Debug的,

                      有知道如何解决这两个问题的,请与我留言,真诚想交往朋友!

QLGame 2d Engine 搭建2d游戏原理的更多相关文章

  1. QLGame 2D Engine编写环境搭建

    QLGame 2D Engine编写 (win7环境搭建) 广州麒麟网络工作室,计划制作一款2d game engine,基于opengl(es)平台,暂时支持android,以后考虑支持linux, ...

  2. QLGame 2d Engine Android端环境搭建(通过jni读取assets目录的文件)

    QLGame 2d Engine win端已经实现了一个动物的动画了,初步的东西已经完成,考虑在Android端也实现这些基本的东西,这样跨平台的引擎也就实现了! 要在Android下编程,首先要实现 ...

  3. QLGame 2d Engine源码地址

    QLGame 2d Engine源码地址已经提交到github上,地址为:https://github.com/wsgzxl/QLGame2dEngine

  4. 简易2D横版RPG游戏制作

    Unity学习笔记1 简易2D横版RPG游戏制作 http://m.blog.csdn.net/article/details?id=24601905

  5. 2d命令行小游戏源码

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  6. Unity3D实现3D立体游戏原理及过程

    Unity3D实现3D立体游戏原理及过程 183 0 0     下面的教程是我今天整理的资料,教大家一步步完成自己的3D立体游戏,并向大家介绍一些3D成像的原理.     理论上,每个普通的非立体3 ...

  7. css3 2D转换(2D Transform) 动画(Animation)

    transform 版本:CSS3 内核类型 写法 Webkit(Chrome/Safari) -webkit-transform Gecko(Firefox) -moz-transform Pres ...

  8. 第九章 nginx基础之搭建小游戏

    一.nginx部署 1.epel源安装 [root@web01 ~]# yum install -y nginx 2.官方源安装 1.配置官方源[root@web02 ~]# vim /etc/yum ...

  9. QLGame 2d Engine SpriteBatch类创建

    GitHub地址:https://github.com/wsgzxl/QLGame2dEngine 今天说五个问题: 1.前面说到的 颜色不对的问题,是因为FreeImage读取出来的数据格式与Ope ...

随机推荐

  1. AIR lame参数配置

    -Duser.name=Z.yu 固定码率的例子:=======================================================================固定码率 ...

  2. iOS之定位与地图

    概览 现在很多社交.电商.团购应用都引入了地图和定位功能,似乎地图功能不再是地图应用 和导航应用所特有的.的确,有了地图和定位功能确实让我们的生活更加丰富多彩,极大的改变了我们的生活方式.例如你到了一 ...

  3. hdu 1587 Flowers

    Flowers Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Su ...

  4. 异步任务(AsyncTask)

    Android的UI线程主要负责处理用户的按键事件.用户触屏事件及屏幕绘图事件等,因此开发者的其他操作不应该.也不能阻塞UI线程,否则UI界面将会变得停止响应——用户感觉非常糟糕.(总之,开发者需要牢 ...

  5. Magento Block设计分析(深入分析)

    Magento中Block是一个很重要的组件,它在Block中充当非常重要的角色,下面我们来分析一下Magento中Block是怎样设计的,我们应该怎样使用这个重要的角色. 1.Magento Blo ...

  6. HDU-1052(贪心策略)

    Tian Ji -- The Horse Racing Problem Description Here is a famous story in Chinese history. "Tha ...

  7. <转载>解决div里面img的缝隙问题

    转载自:http://blog.sina.com.cn/s/blog_9fd5b6df01013mld.html   练习切图时发现img和父级div之间总是有2px空隙(chrome),上网搜索解决 ...

  8. struts中调用servlet的两种方法——IcC方式和非IoC方式的代码demo

    package com.java1234.action;//所在的包 import java.sql.Connection;//数据库连接的类 import java.util.ArrayList;/ ...

  9. hibernate篇章六--demo(Hibernate之第1解之-hibernate_demo_1)

    准备工作做好了,开始Hibernate: 1:建立包:package:dao.model.service.util包: 2:开始model实体类Student:id,sname生成getter/set ...

  10. web开发学习之旅---css第一天

    一.css全称 Cascade Style Sheet层叠样式表 二.css引入方式 行内样式:<h2 style="color:#0F0">Hello World&l ...