文档章节

4。SDL游戏开发:做一个“加法“运算

一一无念
 一一无念
发布于 2012/11/06 00:44
字数 842
阅读 658
收藏 3

当我们刚开吚啊吚的时个,父母就告诉我们,大拇指+食指 = 2,如今,为了在天朝混口饭吃,别把自己当码农,为了和谐社会咱们再来2一回,今天的题目很简单,把两个图片合起来。

 

背景图片:

得到如下图片:

在之前的基础上把代码进得改写

#include "SDL/SDL.h"
#include "SDL/SDL_image.h"
#include <string>

const int SCREEN_WIDTH = 640;
const int SCREEN_HEIGHT = 480;
const int SCREEN_BPP = 32;

//The surfaces
SDL_Surface *background = NULL;
SDL_Surface *foo = NULL;
SDL_Surface *screen = NULL;

//The event structure
SDL_Event event;

SDL_Surface *load_image( std::string filename )
{
    //The image that's loaded
    SDL_Surface* loadedImage = NULL;

    //The optimized image that will be used
    SDL_Surface* optimizedImage = NULL;

    //Load the image
    loadedImage = IMG_Load( filename.c_str() );

    //If the image loaded
    if( loadedImage != NULL ) {
        //Create an optimized image
        optimizedImage = SDL_DisplayFormat( loadedImage );

        //Free the old image
        SDL_FreeSurface( loadedImage );

        //If the image was optimized just fine
        if( optimizedImage != NULL ) {
            //Map the color key
            Uint32 colorkey = SDL_MapRGB( optimizedImage->format, 0, 0xFF, 0xFF );

            //Set all pixels of color R 0, G 0xFF, B 0xFF to be transparent
            SDL_SetColorKey( optimizedImage, SDL_SRCCOLORKEY, colorkey );
        }
    }

    //Return the optimized image
    return optimizedImage;
}

void apply_surface( int x, int y, SDL_Surface* source, SDL_Surface* destination )
{
    //Temporary rectangle to hold the offsets
    SDL_Rect offset;

    //Get the offsets
    offset.x = x;
    offset.y = y;

    //Blit the surface
    SDL_BlitSurface( source, NULL, destination, &offset );
}

bool init()
{
    //初始化所有子系统
    if( SDL_Init( SDL_INIT_EVERYTHING ) == -1 ) {
        return false;
    }

    //Set up the screen
    screen = SDL_SetVideoMode( SCREEN_WIDTH, SCREEN_HEIGHT, SCREEN_BPP, SDL_SWSURFACE );

    //If there was an error in setting up the screen
    if( screen == NULL ) {
        return false;
    }

    //Set the window caption
    SDL_WM_SetCaption( "Foo says \"Hello!\"", NULL );

    //If everything initialized fine
    return true;
}

bool load_files()
{
    //导入背景图片
    background = load_image( "background.png" );

    if( background == NULL ) {
        return false;
    }

    //Load the stick figure
    foo = load_image( "foo.png" );

    //If the stick figure didn't load
    if( foo == NULL ) {
        return false;
    }

    return true;
}

void clean_up()
{
    //Free the surfaces
    SDL_FreeSurface( background );
    SDL_FreeSurface( foo );

    //Quit SDL
    SDL_Quit();
}

int main( int argc, char* args[] )
{
    //Quit flag
    bool quit = false;

    //初始化
    if( init() == false ) {
        return 1;
    }

    //导入图片文件
    if( load_files() == false ) {
        return 1;
    }

    //Apply the surfaces to the screen
    apply_surface( 0, 0, background, screen );
    apply_surface( 240, 190, foo, screen );

    //Update the screen
    if( SDL_Flip( screen ) == -1 ) {
        return 1;
    }

    //While the user hasn't quit
    while( quit == false ) {
        //While there's events to handle
        while( SDL_PollEvent( &event ) ) {
            //If the user has Xed out the window
            if( event.type == SDL_QUIT ) {
                //Quit the program
                quit = true;
            }
        }
    }

    clean_up();

    return 0;
}
保存为sdl04.cpp 编译

g++ -o sdl04 sdl04.cpp -lSDL -lSDL_image
对比于sdl03.cpp发现程序的改变并不大,关键看这几行代码load_image函数里的 

if( optimizedImage != NULL ) {
            //Map the color key
            Uint32 colorkey = SDL_MapRGB( optimizedImage->format, 0, 0xFF, 0xFF );

            //Set all pixels of color R 0, G 0xFF, B 0xFF to be transparent
            SDL_SetColorKey( optimizedImage, SDL_SRCCOLORKEY, colorkey );
        }

里面的SDL_MapRGB这个函数,(提醒大家一下,现在相关SDL的函数在使用的过程中,如果不是很清楚可以通过男人来找,男人不仅找乐子历害,找函数也很拿手哦。


NAME
       SDL_MapRGB - Map a RGB color value to a pixel format.
SYNOPSIS
       #include "SDL.h"
       Uint32 SDL_MapRGB(SDL_PixelFormat *fmt, Uint8 r, Uint8 g, Uint8 b);
就是对某张图片的指定的RGB像素点进行映射。(刚开始的时候,对这个函数,不是很好的理解,通过RGB(0,0XFF,0XFF)指定的颜色是 对比下小人头的图片背景色,原来如此)如果还是不很理解,接下来看了SDL_SetColorKey()函数就会好多了,它的功能就是把上一个函数的进行映射的像素点除去(透明化),可以更解为透明处理,当然还有 启用或禁用RLE的blit加速功能。但是SDL_SetColorKey()只能处理纯色,刚开始还是多贴点注释!
NAME
       SDL_SetColorKey - Sets the color key (transparent pixel) in a blittable
       surface and RLE acceleration.
SYNOPSIS
       #include "SDL.h"
       int SDL_SetColorKey(SDL_Surface *surface, Uint32 flag, Uint32 key);


完成昨晚没有完成的任务,写点东西真不容易!(求职公寓,10平方,两人),这个苦就不说了!

© 著作权归作者所有

一一无念
粉丝 58
博文 36
码字总数 18408
作品 0
长沙
私信 提问
加载中

评论(6)

一一无念
一一无念 博主

引用来自“solu”的评论

init函数的
//初始化所有子系统
if( SDL_Init( SDL_INIT_EVERYTHING ) == -1 ) {
return 1;
}

//If there was an error in setting up the screen
if( screen == NULL ) {
return 1;
}
为什么返回1?!那么main里面的
//初始化
if( init() == false ) {
return 1;
}
不是永远都是真了吗?!

已更正,以后要多检查几次
solu
solu
init函数的
//初始化所有子系统
if( SDL_Init( SDL_INIT_EVERYTHING ) == -1 ) {
return 1;
}

//If there was an error in setting up the screen
if( screen == NULL ) {
return 1;
}
为什么返回1?!那么main里面的
//初始化
if( init() == false ) {
return 1;
}
不是永远都是真了吗?!
红尘一人
红尘一人

引用来自“一一无念”的评论

引用来自“独孤小败”的评论

图片好像挂了

已弄好!

楼主辛苦了 正准备写个SDL的游戏学习下~~有问题看来有人请教了
一一无念
一一无念 博主

引用来自“独孤小败”的评论

图片好像挂了

已弄好!
红尘一人
红尘一人

引用来自“独孤小败”的评论

图片好像挂了

+1
独孤小败
独孤小败
图片好像挂了
[NBOJ0031][Nim-B* Sum]

[题目要求] http://acm.bupt.edu.cn/onlinejudge/newoj/showProblem/showproblem.php?problem_id=31 [题目涉及的相关理论与算法] 1,博弈论中的NIM游戏。虽然题目中求的Nim和是Nim游戏中的策...

小弘
2012/10/13
121
0
5. SDL游戏开发:肢解“人民币“

在上一篇文章里,我们做了一个“加法”把两张图片合成,费了好大功夫才搞定,要是用PS可快了,我说哥们,这没可比性!现在要做减法,就好比你工作是挣钱,你总得花钱吧!上大学的时候,有这么...

一一无念
2012/11/06
962
1
计算机只会加法,原码,反码,补码和移码的相关概念

计算机只会加法,原码,反码,补码和移码的相关概念 计算机只会算加法 4+2 = 4+2 4-2 = 4+(-2) 2*4 = 2+2+2+2 8/2 = 8-2-2-2-2 = 8+(-2)+(-2)+(-2)+(-2) = 0 数据结构中的原码 反码 补码就是因应...

长平狐
2012/09/03
156
0
函数参数和函数返回值

函数参数和函数返回值 函数参数 思考一个问题,如下: 现在需要定义一个函数,这个函数能够完成2个数的加法运算,并且把结果打印出来,该怎样设计?下面的代码可以吗?有什么缺陷吗? 为了让...

祈澈姑娘
2018/02/01
0
0
聊聊从逻辑门到操作系统的计算机

前言 现代计算机已经发展的非常复杂,要理解计算机的运行原理都已经变得异常艰难,虽说我们无法亲自去制造他,但我们可以了解下计算机系统是怎么从0发展而来的。 逻辑门 逻辑门是计算机的基础...

超人汪小建
2018/07/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

idea修改新的git地址

我们在项目变动中通常会遇到更换git地址情况,这里介绍一个在idea项目中简单更换git地址操作: 1、点击VCS; 2、点击Git; 3、点击Remotes; 具体步骤如图 4、点击框中链接即可在右边看到一个...

west_coast
32分钟前
6
0
将规则集传递给mixin

允许包装在mixin中定义的css块。 分离的规则集是一组CSS属性、嵌套规则集、媒体声明或者是存储在变量中的任何其他内容,我们可以将它包含在规则集中或其他结构中,并且所有属性都将复制到那里...

凌兮洛
33分钟前
4
0
玩转阿里云 Terraform(一):Terraform 是什么

从本文起,我将陆续推出一系列有关 Terraform 的文章,从概念,特点,工作机制,用法以及最佳实践等多个方面由浅入深的向大家介绍如何在阿里云上玩转 Terraform。同时也希望借此机会,与感兴...

阿里云官方博客
34分钟前
4
0
科研大数据面临的挑战

近几十年硬件的发展非常迅猛,第一台Macintosh苹果电脑的内存是128KB(0.13MB),现在很多笔记本配的是8GB的内存,硬盘1TB(1024GB),2TB的很常见。大型的数据服务器上还会有更大的储容量,...

英论阁学术院
34分钟前
5
0
python学习10.09:Python列表和元组的底层实现

有关列表(list)和元组(tuple)的底层实现,本节分别从它们的源码来进行分析。 首先来分析 list 列表,它的具体结构如下所示: typedef struct { PyObject_VAR_HEAD /* Vector o...

太空堡垒185
35分钟前
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部