我正在尝试创建一个用于像素操作的 SDL_Surface,但是在设置表面的颜色掩码时确实出了点问题,因为填充颜色缓冲区时颜色不正确(请参阅评论,我正在尝试解释u8vec4 作为 RGBA 颜色):
const int win_width = 640;
const int win_height = 480;
std::vector<glm::u8vec4> colors{ win_width * win_height, glm::u8vec4{ 0, 0, 0, 0 } };
SDL_Surface* render_surface = SDL_CreateRGBSurfaceFrom(&colors[0], win_width, win_height, 32,
sizeof(glm::u8vec4) * win_width, 0xFF000000, 0x00FF0000, 0x0000FF00, 0x000000FF);
SDL_Texture* render_texture = SDL_CreateTexture(renderer, SDL_PIXELFORMAT_RGBA8888,
SDL_TEXTUREACCESS_STREAMING, win_width, win_height);
// { 255, 0, 0, 255 } = Red
// { 255, 0, 0, 100 } = Darker red, alpha seems to be working
// { 0, 255, 0, 255 } = Purple!? Should be green?
// { 0, 0, 255, 255 } = Yellow, expecting blue
std::fill(colors.begin(), colors.end(), glm::u8vec4{ 0, 0, 0, 255 }); // Red
SDL_UpdateTexture(render_texture, nullptr, render_surface->pixels, render_surface->pitch);
SDL_RenderClear(renderer);
SDL_RenderCopy(renderer, render_texture, nullptr, nullptr);
SDL_RenderPresent(renderer);
最佳答案
你应该尝试根据字节序设置你的 bitmaks。这是我的做法:
#if SDL_BYTEORDER == SDL_BIG_ENDIAN
const uint32_t R_MASK = 0xff000000;
const uint32_t G_MASK = 0x00ff0000;
const uint32_t B_MASK = 0x0000ff00;
const uint32_t A_MASK = 0x000000ff;
#else
const uint32_t R_MASK = 0x000000ff;
const uint32_t G_MASK = 0x0000ff00;
const uint32_t B_MASK = 0x00ff0000;
const uint32_t A_MASK = 0xff000000;
#endif
在您的情况下,您已经以相反的方式获得了色罩。
我认为 Jongware 是正确的,格式是 ABGR。
// { 255, 0, 0, 100 } = Darker red, alpha seems to be working
我猜这里的 alpha 似乎是正确的,因为背景是黑色的,通过将红色的数量减少到 100,它会自然地融入背景。
我还认为你没有设置SDL_BlendMode
关于c++ - SDL2 纹理的像素格式和表面颜色 mask ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23959896/