summaryrefslogtreecommitdiffhomepage
path: root/dev/Kernel/Modules/CoreCG/FbRenderer.hxx
diff options
context:
space:
mode:
authorAmlal EL Mahrouss <amlalelmahrouss@icloud.com>2024-08-15 18:35:34 +0200
committerAmlal EL Mahrouss <amlalelmahrouss@icloud.com>2024-08-15 18:35:34 +0200
commitf3d931aa7cfaf96baef8383b59a8938779541ee7 (patch)
treefdb9fc51badb3dbd03e46ab0766a49d9522e13e2 /dev/Kernel/Modules/CoreCG/FbRenderer.hxx
parent86640816e8b1d3595365f1fcc8a2a9e61fb40ff1 (diff)
[IMP] Moved source code into dev/ folder.
Signed-off-by: Amlal EL Mahrouss <amlalelmahrouss@icloud.com>
Diffstat (limited to 'dev/Kernel/Modules/CoreCG/FbRenderer.hxx')
-rw-r--r--dev/Kernel/Modules/CoreCG/FbRenderer.hxx79
1 files changed, 79 insertions, 0 deletions
diff --git a/dev/Kernel/Modules/CoreCG/FbRenderer.hxx b/dev/Kernel/Modules/CoreCG/FbRenderer.hxx
new file mode 100644
index 00000000..06c27949
--- /dev/null
+++ b/dev/Kernel/Modules/CoreCG/FbRenderer.hxx
@@ -0,0 +1,79 @@
+/* -------------------------------------------
+
+ Copyright ZKA Technologies.
+
+------------------------------------------- */
+
+#pragma once
+
+#include <NewKit/Defines.hxx>
+
+#define CGInit() Kernel::SizeT __GXCursor = 0
+
+#define CGColor(R, G, B) RGB(R, G, B)
+
+#define cCGClearClr CGColor(0x0, 0x0, 0x0)
+
+#define CGFini() __GXCursor = 0
+
+/// @brief Performs OR drawing on the framebuffer.
+#define CGDrawBitMapInRegionA(ImgPtr, _Height, _Width, BaseX, BaseY) \
+ __GXCursor = 0; \
+ \
+ for (Kernel::SizeT i = BaseX; i < (_Height + BaseX); ++i) \
+ { \
+ for (Kernel::SizeT u = BaseY; u < (_Width + BaseY); ++u) \
+ { \
+ *(((volatile Kernel::UInt32*)(kHandoverHeader->f_GOP.f_The + \
+ 4 * kHandoverHeader->f_GOP.f_PixelPerLine * \
+ i + \
+ 4 * u))) |= (ImgPtr)[__GXCursor]; \
+ \
+ ++__GXCursor; \
+ } \
+ }
+
+/// @brief Draws a resource.
+#define CGDrawBitMapInRegion(ImgPtr, _Height, _Width, BaseX, BaseY) \
+ __GXCursor = 0; \
+ \
+ for (Kernel::SizeT i = BaseX; i < (_Height + BaseX); ++i) \
+ { \
+ for (Kernel::SizeT u = BaseY; u < (_Width + BaseY); ++u) \
+ { \
+ *(((volatile Kernel::UInt32*)(kHandoverHeader->f_GOP.f_The + \
+ 4 * kHandoverHeader->f_GOP.f_PixelPerLine * \
+ i + \
+ 4 * u))) = (ImgPtr)[__GXCursor]; \
+ \
+ ++__GXCursor; \
+ } \
+ }
+
+/// @brief Cleans a resource.
+#define CGClearRegion(_Height, _Width, BaseX, BaseY) \
+ \
+ for (Kernel::SizeT i = BaseX; i < _Height + BaseX; ++i) \
+ { \
+ for (Kernel::SizeT u = BaseY; u < _Width + BaseY; ++u) \
+ { \
+ *(((volatile Kernel::UInt32*)(kHandoverHeader->f_GOP.f_The + \
+ 4 * kHandoverHeader->f_GOP.f_PixelPerLine * \
+ i + \
+ 4 * u))) = cCGClearClr; \
+ } \
+ }
+
+/// @brief Draws inside a zone.
+#define CGDrawInRegion(_Clr, _Height, _Width, BaseX, BaseY) \
+ \
+ for (Kernel::SizeT x_base = BaseX; x_base < (_Width + BaseX); ++x_base) \
+ { \
+ for (Kernel::SizeT y_base = BaseY; y_base < (_Height + BaseY); ++y_base) \
+ { \
+ *(((volatile Kernel::UInt32*)(kHandoverHeader->f_GOP.f_The + \
+ 4 * kHandoverHeader->f_GOP.f_PixelPerLine * \
+ x_base + \
+ 4 * y_base))) = _Clr; \
+ } \
+ }