Merge pull request #597 from bunnei/fix-color-component-order
Rasterize with the correct color component order.
This commit is contained in:
		| @@ -20,7 +20,7 @@ namespace Rasterizer { | |||||||
|  |  | ||||||
| static void DrawPixel(int x, int y, const Math::Vec4<u8>& color) { | static void DrawPixel(int x, int y, const Math::Vec4<u8>& color) { | ||||||
|     const PAddr addr = registers.framebuffer.GetColorBufferPhysicalAddress(); |     const PAddr addr = registers.framebuffer.GetColorBufferPhysicalAddress(); | ||||||
|     u32* color_buffer = reinterpret_cast<u32*>(Memory::GetPointer(PAddrToVAddr(addr))); |     u8* color_buffer = Memory::GetPointer(PAddrToVAddr(addr)); | ||||||
|  |  | ||||||
|     // Similarly to textures, the render framebuffer is laid out from bottom to top, too. |     // Similarly to textures, the render framebuffer is laid out from bottom to top, too. | ||||||
|     // NOTE: The framebuffer height register contains the actual FB height minus one. |     // NOTE: The framebuffer height register contains the actual FB height minus one. | ||||||
| @@ -29,8 +29,11 @@ static void DrawPixel(int x, int y, const Math::Vec4<u8>& color) { | |||||||
|     switch (registers.framebuffer.color_format) { |     switch (registers.framebuffer.color_format) { | ||||||
|     case registers.framebuffer.RGBA8: |     case registers.framebuffer.RGBA8: | ||||||
|     { |     { | ||||||
|         u32 value = (color.a() << 24) | (color.r() << 16) | (color.g() << 8) | color.b(); |         u8* pixel = color_buffer + (x + y * registers.framebuffer.GetWidth()) * 4; | ||||||
|         *(color_buffer + x + y * registers.framebuffer.GetWidth()) = value; |         pixel[3] = color.r(); | ||||||
|  |         pixel[2] = color.g(); | ||||||
|  |         pixel[1] = color.b(); | ||||||
|  |         pixel[0] = color.a(); | ||||||
|         break; |         break; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -42,17 +45,27 @@ static void DrawPixel(int x, int y, const Math::Vec4<u8>& color) { | |||||||
|  |  | ||||||
| static const Math::Vec4<u8> GetPixel(int x, int y) { | static const Math::Vec4<u8> GetPixel(int x, int y) { | ||||||
|     const PAddr addr = registers.framebuffer.GetColorBufferPhysicalAddress(); |     const PAddr addr = registers.framebuffer.GetColorBufferPhysicalAddress(); | ||||||
|     u32* color_buffer_u32 = reinterpret_cast<u32*>(Memory::GetPointer(PAddrToVAddr(addr))); |     u8* color_buffer = Memory::GetPointer(PAddrToVAddr(addr)); | ||||||
|  |  | ||||||
|     y = (registers.framebuffer.height - y); |     y = (registers.framebuffer.height - y); | ||||||
|  |  | ||||||
|     u32 value = *(color_buffer_u32 + x + y * registers.framebuffer.GetWidth()); |     switch (registers.framebuffer.color_format) { | ||||||
|     Math::Vec4<u8> ret; |     case registers.framebuffer.RGBA8: | ||||||
|     ret.a() = value >> 24; |     { | ||||||
|     ret.r() = (value >> 16) & 0xFF; |         Math::Vec4<u8> ret; | ||||||
|     ret.g() = (value >> 8) & 0xFF; |         u8* pixel = color_buffer + (x + y * registers.framebuffer.GetWidth()) * 4; | ||||||
|     ret.b() = value & 0xFF; |         ret.r() = pixel[3]; | ||||||
|     return ret; |         ret.g() = pixel[2]; | ||||||
|  |         ret.b() = pixel[1]; | ||||||
|  |         ret.a() = pixel[0]; | ||||||
|  |         return ret; | ||||||
|  |     } | ||||||
|  |     default: | ||||||
|  |         LOG_CRITICAL(Render_Software, "Unknown framebuffer color format %x", registers.framebuffer.color_format); | ||||||
|  |         UNIMPLEMENTED(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return {}; | ||||||
|  } |  } | ||||||
|  |  | ||||||
| static u32 GetDepth(int x, int y) { | static u32 GetDepth(int x, int y) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 bunnei
					bunnei