87 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			87 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|  | #pragma once
 | ||
|  | 
 | ||
|  | #include <kinc/global.h>
 | ||
|  | 
 | ||
|  | #include <kinc/color.h>
 | ||
|  | 
 | ||
|  | #include <assert.h>
 | ||
|  | 
 | ||
|  | /*! \file graphics.h
 | ||
|  |     \brief Supports a very basic pixel-setting API. | ||
|  | */ | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | extern "C" { | ||
|  | #endif
 | ||
|  | 
 | ||
|  | /// <summary>
 | ||
|  | /// Initializes the G1-API.
 | ||
|  | /// </summary>
 | ||
|  | /// <param name="width">The width to be used by the G1-API - typically the window-width</param>
 | ||
|  | /// <param name="height">The height to be used by the G1-API - typically the window-height</param>
 | ||
|  | KINC_FUNC void kinc_g1_init(int width, int height); | ||
|  | 
 | ||
|  | /// <summary>
 | ||
|  | /// Typically called once per frame before other G1-functions are called.
 | ||
|  | /// </summary>
 | ||
|  | KINC_FUNC void kinc_g1_begin(void); | ||
|  | 
 | ||
|  | /// <summary>
 | ||
|  | /// Typically called once per frame after all G1-drawing is finished. This also swaps the framebuffers
 | ||
|  | /// so an equivalent call to kinc_g4_swap_buffers is not needed.
 | ||
|  | /// </summary>
 | ||
|  | KINC_FUNC void kinc_g1_end(void); | ||
|  | 
 | ||
|  | extern uint32_t *kinc_internal_g1_image; | ||
|  | extern int kinc_internal_g1_w, kinc_internal_g1_h, kinc_internal_g1_tex_width; | ||
|  | 
 | ||
|  | #if defined(KINC_DYNAMIC_COMPILE) || defined(KINC_DYNAMIC) || defined(KINC_DOCS)
 | ||
|  | 
 | ||
|  | /// <summary>
 | ||
|  | /// Sets a single pixel to a color.
 | ||
|  | /// </summary>
 | ||
|  | /// <param name="x">The x-component of the pixel-coordinate to set</param>
 | ||
|  | /// <param name="y">The y-component of the pixel-coordinate to set</param>
 | ||
|  | /// <param name="red">The red-component between 0 and 1</param>
 | ||
|  | /// <param name="green">The green-component between 0 and 1</param>
 | ||
|  | /// <param name="blue">The blue-component between 0 and 1</param>
 | ||
|  | KINC_FUNC void kinc_g1_set_pixel(int x, int y, float red, float green, float blue); | ||
|  | 
 | ||
|  | /// <summary>
 | ||
|  | /// Returns the width used by G1.
 | ||
|  | /// </summary>
 | ||
|  | /// <returns>The width</returns>
 | ||
|  | KINC_FUNC int kinc_g1_width(void); | ||
|  | 
 | ||
|  | /// <summary>
 | ||
|  | /// Returns the height used by G1.
 | ||
|  | /// </summary>
 | ||
|  | /// <returns>The height</returns>
 | ||
|  | KINC_FUNC int kinc_g1_height(void); | ||
|  | 
 | ||
|  | #else
 | ||
|  | 
 | ||
|  | // implementation moved to the header to allow easy inlining
 | ||
|  | 
 | ||
|  | static inline void kinc_g1_set_pixel(int x, int y, float red, float green, float blue) { | ||
|  | 	assert(x >= 0 && x < kinc_internal_g1_w && y >= 0 && y < kinc_internal_g1_h); | ||
|  | 	int r = (int)(red * 255); | ||
|  | 	int g = (int)(green * 255); | ||
|  | 	int b = (int)(blue * 255); | ||
|  | 	kinc_internal_g1_image[y * kinc_internal_g1_tex_width + x] = 0xff << 24 | b << 16 | g << 8 | r; | ||
|  | } | ||
|  | 
 | ||
|  | static inline int kinc_g1_width(void) { | ||
|  | 	return kinc_internal_g1_w; | ||
|  | } | ||
|  | 
 | ||
|  | static inline int kinc_g1_height(void) { | ||
|  | 	return kinc_internal_g1_h; | ||
|  | } | ||
|  | 
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | } | ||
|  | #endif
 |