SDL2_image渲染无法正常工作

问题描述 投票:1回答:2

我正在尝试使用SDL2中的SDL_image v2.0.0渲染图像。

我在res / img /文件夹中有一个名为Red.png的图像。当我尝试加载纹理并使用SDL_QueryTexture()时,它将获得大小,一切都很好。但是,在渲染实际图像时,我已经放置了一个矩形轮廓以知道该图像在哪里,但是框中没有图像。

我用来加载和渲染纹理的类:

class LTexture
{
public:

    ~LTexture()
    {
        SDL_DestroyTexture(image_);
        renderer_ = nullptr;
        image_ = nullptr;
    }

    void init(SDL_Renderer* renderer)
    {
        printf("init texture\n");
        renderer_ = renderer;
    }

    void loadBMP(std::string filename)
    {
        printf("load texture\n");
        image_ = IMG_LoadTexture(renderer_, ("res/img/"+filename).c_str());
        SDL_QueryTexture(image_, NULL, NULL, &imgrect.w, &imgrect.h);
    }

    void render(int x, int y)
    {
        imgrect.x = x;
        imgrect.y = y;
        SDL_SetRenderDrawColor(renderer_, 128, 128, 128, 255);
        if (image_ != nullptr && renderer_ != nullptr)
        {
            printf("%i,  %i\n", imgrect.x, imgrect.y);
            SDL_RenderDrawRect(renderer_, &imgrect);
            SDL_RenderCopy(renderer_, image_, &imgrect, &imgrect);
        }
    }

    bool isLoaded()
    {
        return image_ != nullptr;
    }

private:
    SDL_Renderer* renderer_ = nullptr;
    SDL_Texture* image_ = nullptr;
    SDL_Rect imgrect;

};

我知道它正确地获取了渲染器并加载了图像,因为DrawRect函数可以正常工作,如果您未按名称猜测,Red.png是一个红色矩形。

c++ image textures sdl
2个回答
1
投票

在您的nullptr通话中将srcrect传递给SDL_RenderCopy()

SDL_RenderCopy(renderer_, image_, nullptr, &imgrect);

现在,如果x和/或y大于image_,SDL将把srcrect裁剪到image_的程度,最后得到一个空的矩形,什么也不做。

实施例:

#include <SDL2/SDL.h>
#include <SDL2/SDL_image.h>

#include <cstdlib>
#include <string>

class LTexture
{
public:

    LTexture()
        : renderer_( nullptr )
        , image_( nullptr )
    { }

    ~LTexture()
    {
        SDL_DestroyTexture(image_);
        renderer_ = nullptr;
        image_ = nullptr;
    }

    void init(SDL_Renderer* renderer)
    {
        printf("init texture\n");
        renderer_ = renderer;
    }

    void loadBMP(std::string filename)
    {
        printf("load texture\n");
        image_ = IMG_LoadTexture(renderer_, filename.c_str());
        SDL_QueryTexture(image_, NULL, NULL, &imgrect.w, &imgrect.h);
    }

    void render(int x, int y)
    {
        imgrect.x = x;
        imgrect.y = y;
        SDL_SetRenderDrawColor(renderer_, 128, 128, 128, 255);
        if (image_ != nullptr && renderer_ != nullptr)
        {
            printf("%i,  %i\n", imgrect.x, imgrect.y);
            SDL_RenderDrawRect(renderer_, &imgrect);
            SDL_RenderCopy(renderer_, image_, nullptr, &imgrect);
        }
    }

    bool isLoaded()
    {
        return image_ != nullptr;
    }

private:
    SDL_Renderer* renderer_;
    SDL_Texture* image_;
    SDL_Rect imgrect;
};


int main( int argc, char** argv )
{
    SDL_Init( SDL_INIT_EVERYTHING );
    IMG_Init( IMG_INIT_PNG );

    SDL_Window * window = SDL_CreateWindow
        (
        "SDL2", 
        SDL_WINDOWPOS_CENTERED, SDL_WINDOWPOS_CENTERED, 
        300, 300, 
        SDL_WINDOW_SHOWN
        );

    SDL_Renderer* renderer = SDL_CreateRenderer
        (
        window,
        0,
        SDL_RENDERER_ACCELERATED
        );

    LTexture tex;
    tex.init( renderer );
    tex.loadBMP( "red.png" );

    bool running = true;
    while( running )
    {
        SDL_Event ev;
        while( SDL_PollEvent( &ev ) )
        {
            if ( ev.type == SDL_QUIT )
                running = false;
        }

        SDL_SetRenderDrawColor( renderer, 0, 0, 0, 255 );
        SDL_RenderFillRect( renderer, NULL );

        tex.render( 50, 50 );

        SDL_RenderPresent( renderer );
        SDL_Delay( 33 );
    }

    SDL_DestroyRenderer( renderer );
    SDL_DestroyWindow( window );

    IMG_Quit();
    SDL_Quit();

    return 0;
}

red.png供参考:

red.png


0
投票

我不知道这是否仍然可行,但是当我使用SW加速时,SDL_Render *可以使用SDL_RENDERER_ACCELERATED标志(在Linuix Mint下)遇到问题。

© www.soinside.com 2019 - 2024. All rights reserved.