682 lines
23 KiB
C

/****************************************************************************
*
* Copyright 2012 - 2020 Vivante Corporation, Santa Clara, California.
* All Rights Reserved.
*
* Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
* 'Software'), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sub license, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject
* to the following conditions:
*
* The above copyright notice and this permission notice (including the
* next paragraph) shall be included in all copies or substantial
* portions of the Software.
*
* THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
* IN NO EVENT SHALL VIVANTE AND/OR ITS SUPPLIERS BE LIABLE FOR ANY
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*
*****************************************************************************/
#ifndef ELM_H_
#define ELM_H_
#ifdef __cplusplus
extern "C" {
#endif
#define ELM_VERSION 0x00010000 /* Current Version: 1.0. */
#define ELM_NULL_HANDLE 0 /*! NULL object handle, represent a void object. */
/*!
@typedef ELM_EVO_PROP_BIT
evo property bits to control evo manipulation.
*/
typedef enum {
ELM_PROP_ROTATE_BIT = 1 << 0, /*! rotate bit of evo/ego/ebo transformation property. */
ELM_PROP_TRANSFER_BIT = 1 << 1, /*! transfer bit of evo/ego/ebo transformation property. */
ELM_PROP_SCALE_BIT = 1 << 2, /*! scale bit of evo/ego/ebo transformation property. */
ELM_PROP_BLEND_BIT = 1 << 3, /*! blending bit of evo/ebo rendering property. */
ELM_PROP_QUALITY_BIT = 1 << 4, /*! quality bit of evo/ebo rendering property. */
ELM_PROP_FILL_BIT = 1 << 5, /*! fill rule bit of evo rendering property. */
ELM_PROP_COLOR_BIT = 1 << 6, /*! fill color bit of evo rendering property. */
ELM_PROP_PAINT_BIT = 1 << 7, /*! paint type bit of evo. */
ELM_PROP_ALL_BIT = 0xFFFFFFFF, /*! all transformation property bits of evo. */
} ELM_EVO_PROP_BIT;
/*!
@typedef ELM_EVO_BLEND
The blending property of the evo object when it's drawn.
D is Destination color, S is Source color;
Da is Destination alpha, S is Source alpha.
*/
typedef enum {
ELM_BLEND_NONE = 0, /*! D = S. */
ELM_BLEND_SRC_OVER, /*! D = S + (1 - Sa) * D */
ELM_BLEND_DST_OVER, /*! D = (1 - Da) * S + D */
ELM_BLEND_SRC_IN, /*! D = Da * S */
ELM_BLEND_DST_IN, /*! D = Sa * D */
ELM_BLEND_SCR, /*! D = S + D - S * D */
ELM_BLEND_MUL, /*! D = S * (1 - Da) + D * (1 - Sa) + S * D */
ELM_BLEND_ADD, /*! S + D */
ELM_BLEND_SUB /*! D * (1 - S) */
} ELM_BLEND;
/*!
@typedef ELM_EVO_QUALITY
The drawing quality of the evo object.
*/
typedef enum {
ELM_QUALITY_LOW = 0, /*! NOAA for evo, POINT SAMPLE for ebo. */
ELM_QUALITY_MED = 1, /*! 2XAA for evo, LINEAR SAMPLE for ebo. */
ELM_QULIATY_HI = 2, /*! 4XAA for evo, BI-LINEAR SAMPLE for ebo. */
} ELM_QUALITY;
/*!
@typedef ELM_PAINT_TYPE
Those are types for evo fill paint.
COLOR means solid color fill;
PATTERN means fill with an image (evo);
GRADIENT means fill with linear gradient.
*/
typedef enum {
ELM_PAINT_COLOR = 0, /*! Paint evo with solid color */
ELM_PAINT_PATTERN = 1, /*! Paint evo with ebo */
ELM_PAINT_GRADIENT = 2, /*! Paint evo with a linear gradient built-in evo object */
ELM_PAINT_RADIAL_GRADIENT = 3, /*! Paint evo with a radial gradient built-in evo object */
ELM_PAINT_TEXT = 4, /*! Paint evo-text */
} ELM_PAINT_TYPE;
/*!
@typedef ELM_PATTERN_MODE
Those are enum types for pattern fill mode.
COLOR means fill the area outside the pattern with a solid color;
PAD means extend the border color to the area outside the pattern.
*/
typedef enum {
ELM_PATTERN_MODE_COLOR = 0,
ELM_PATTERN_MODE_PAD = 1,
} ELM_PATTERN_MODE;
/*!
@typedef ELM_EVO_FILL
The filling rule of for an evo object.
EO = EVEN_ODD;
NZ = NONE_ZERO;
*/
typedef enum {
ELM_EVO_FILL_NZ = 0, /*! none-zero fill rule */
ELM_EVO_FILL_EO = 1, /*! Even-odd fill rule */
} ELM_EVO_FILL;
/*!
@typedef ELM_EVO_TYPE
the type of an evo object. could be pathes, images, or a group which contains other EVOs.
*/
typedef enum {
ELM_OBJECT_TYPE_EVO = 0, /*! elementary vector object, representing a path object. */
ELM_OBJECT_TYPE_EGO = 1, /*! elementary group object, containing multiple path objects. */
ELM_OBJECT_TYPE_EBO = 2, /*! elementary bitmap object, representing image data. */
ELM_OBJECT_TYPE_BUF = 3, /*! rendering buffer object, created by application. */
ELM_OBJECT_TYPE_FONT = 4, /*! elementary font object, representing character data. */
ELM_OBJECT_TYPE_TEXT = 5, /*! elementary text object, representing text data. */
} ELM_OBJECT_TYPE;
/*!
@typedef ELM_BUFFER_FORMAT
Enumeration for buffer format, all format name definiton is sequenced from LSB to MSB.
*/
typedef enum {
ELM_BUFFER_FORMAT_RGBA8888, /*! 32-bit RGBA format with 8 bits per color channel. Red is in bits 7:0, green in bits 15:8, blue in
bits 23:16, and the alpha channel is in bits 31:24. */
ELM_BUFFER_FORMAT_BGRA8888, /*! 32-bit RGBA format with 8 bits per color channel. Red is in bits 23:16, green in bits 15:8, blue in
bits 7:0, and the alpha channel is in bits 31:24. */
ELM_BUFFER_FORMAT_RGBX8888, /*! 32-bit RGBX format with 8 bits per color channel. Red is in bits 7:0, green in bits 15:8, blue in
bits 23:16, and the x channel is in bits 31:24. */
ELM_BUFFER_FORMAT_BGRX8888, /*! 32-bit RGBX format with 8 bits per color channel. Red is in bits 23:16, green in bits 15:8, blue in
bits 7:0, and the x channel is in bits 31:24. */
ELM_BUFFER_FORMAT_RGB565, /*! 16-bit RGB format with 5 and 6 bits per color channel. Red is in bits 4:0, green in bits 10:5, and
the blue color channel is in bits 15:11. */
ELM_BUFFER_FORMAT_BGR565, /*! 16-bit RGB format with 5 and 6 bits per color channel. Red is in bits 15:11, green in bits 10:5,
and the blue color channel is in bits 4:0. */
ELM_BUFFER_FORMAT_RGBA4444, /*! 16-bit RGBA format with 4 bits per color channel. Red is in bits 3:0, green in bits 7:4, blue in
bits 11:8 and the alpha channel is in bits 15:12. */
ELM_BUFFER_FORMAT_BGRA4444, /*! 16-bit RGBA format with 4 bits per color channel. Red is in bits 11:8, green in bits 7:4, blue in
bits 3:0 and the alpha channel is in bits 15:12. */
ELM_BUFFER_FORMAT_BGRA5551, /*! 16-bit RGBA format with 4 bits per color channel. Red is in bits 14:10, green in bits 9:5, blue in
bits 4:0 and the alpha channel is in bit 15:15. */
ELM_BUFFER_FORMAT_INDEX_1, /*! 1-bit indexed format. */
ELM_BUFFER_FORMAT_INDEX_2, /*! 2-bits indexed format. */
ELM_BUFFER_FORMAT_INDEX_4, /*! 4-bits indexed format. */
ELM_BUFFER_FORMAT_INDEX_8, /*! 8-bits indexed format. */
} ELM_BUFFER_FORMAT;
/*!
@typedef ElmHandle
common handle type for object reference.
*/
typedef unsigned int ElmHandle;
/*!
@typedef ElmVecObj
evo object handle (elemtry vector object). Created from an external binary evo file.
*/
typedef ElmHandle ElmVecObj;
/*!
@typedef ElmBitmapObj
ebo object handle (elementry image object). Created from an external ebo file.
*/
typedef ElmHandle ElmBitmapObj;
/*!
@typedef ElmGroupObj
group object handle. Create from an external ego file.
*/
typedef ElmHandle ElmGroupObj;
/*!
@typedef ElmBuffer
render buffer object handle.
*/
typedef ElmHandle ElmBuffer;
#define TRUE 1
#define FALSE 0
/*!
@typedef BOOL
boolean type define.
*/
typedef unsigned int BOOL;
/*!
@abstract Initialize Elementary context.
@discussion
It should be called as the first function of Elemenatary libary, which initializes the library. Currently
Elementary library doesn't support context concept, neigher multi-threading. Elementary library defines
origin of coordinate system is at top-left.
@param none
@return none
*/
BOOL ElmInitialize(uint32_t width, uint32_t height);
/*!
@abstract Terminate Elementary context.
@discussion
This should be called when an app exits. It frees all the resource.
@param none
@return none
*/
void ElmTerminate(void);
/*!
@abstract Create an elementary object from an existing binary file.
@discussion
This function creates an elementary object from the file whose file name is specified by param name.
Caller must match type with the binary file, otherwise create mail fail by returning ELM_NULL_HANDLE.
@param type
Specify what type of object to be created.
@param name
The name of the binary resource file.
@return ElmHandle
An object handle depending on the corresponding type. If type mismatches, it
returns ELM_NULL_HANDLE.
*/
ElmHandle ElmCreateObjectFromFile(ELM_OBJECT_TYPE type, const char *name);
/*!
@abstract Create an elementary object from build-in data within the appplication.
@discussion
This function creates an elementar object from local data pointer, which is specially useful for environment without filesystem support.
@param type
Specify what type of object to be created.
@param data
The pointer to the binary data which has exactly same layout as external resource file.
@return ElmHandle
An object handle depending on the corresponding type. If type mismatches with the binary data, it
returns ELM_NULL_HANDLE.
*/
ElmHandle ElmCreateObjectFromData(ELM_OBJECT_TYPE type, void *data, int size);
/*!
@abstract Rotate a graphics object with centain degree
@discussion
This function sets an evo/ebo/ego object rotated with specified angle. Without reset, these setting will be
accumulated.
@param obj
The graphics object will be rotated.
@param angle
A radian value to be applied on the evo object.
@return bool
Rotate is set successfully.
*/
BOOL ElmRotate(ElmHandle obj, float angle);
/*!
@abstract Transfer an graphics object at different directions.
@discussion
This function put an evo/ebo/ego object away at different directions. Without reset, the setting will be
accumulated.
@param obj
The graphics object will be transfered.
@param x
The units in pixel of X direction.
@param y
The units in pixel of Y direction.
@return bool
Transfer is set successfully.
*/
BOOL ElmTransfer(ElmHandle obj, int x, int y);
/*!
@abstract Scale an graphics object at different directions.
@discussion
This function scale up or down an evo/ego/ebo object at different directions. Without reset, the setting will
be accumateled.
@param obj
The graphics object which is targeted to manipulate.
@param x
The scale ratio in X direction.
@param y
The scale ratio in Y direction.
@return bool
Scale is set succefully.
*/
BOOL ElmScale(ElmHandle obj, float x, float y);
/*!
@abstract Reset the attribute of a graphics object for specified property bit.
@discussion
This funcion resets specified property for an elementary object. It can be applied all types of objects.
But some properties are only valid for centain types of objects. If the function is called to reset an invalid
property for this type of object, it will be siliently ignored.
After reset, the specifed property of an evo/ebo/ego object is set to the initial state. The initial states are decided
by the binary resource file. The resource creator should set right value for all properties if they want to directly render
the object without any adjustment in application. There is one issue, at present, application has no way to query current value
of each property, is it required?
@param obj
The graphics object which is targeted to manipulate.
@param mask
Specify which property or properties need to reset to initial value.
@return bool
Reset is done successfully. If some mask is not valid for this type of object, it would return false.
*/
BOOL ElmReset(ElmHandle obj, ELM_EVO_PROP_BIT mask);
/*!
@abstract Draw a graphics object onto current render target
@discussion
This is an enssentail function to do the real job, it takes all current setting of the elementary object and
render into theb buffer target.
@param buffer
The render target that an elmentary object will be rendered into.
@param obj
The elmentary object will be draw into render target.
@return bool
The draw operation for this elmentary object is sucessful.
*/
BOOL ElmDraw(ElmBuffer buffer, ElmHandle object);
/*!
@abstract Set the rendering quality of an graphics object.
@discussion
This function sets the rendering quality of an evo/ebo object. Avaliable quality setting contains:
ELM_EVO_QUALITY_LOW, ELM_EVO_QUALITY_MED, ELM_EVO_QUALITY_HI. This function is only applied to an evo or an ebo.
Group object can't be set quality. It always use the setting from its binary.
@param obj
The elementary object.
@param quality
The quality enum.
@return bool
The operation for this object is sucessful, for group object and invalid enum, would return false.
*/
BOOL ElmSetQuality(ElmHandle obj, ELM_QUALITY quality);
/*!
@abstract Set the fill rule of an evo object.
@discussion
This function sets the fill rule of an elementary object. Avaliable quality setting contains:
ELM_EVO_EO, ELM_EVO_NZ. It only applies to evo object.
@param evo
The evo object.
@param fill
The fill rule enum.
@return bool
The operation for this evo is sucessful. For non-evo object an ENUM is not a valid enum, would return false.
*/
BOOL ElmSetFill(ElmVecObj evo, ELM_EVO_FILL fill);
/*!
@abstract Set the blending mode of an evo/ebo object.
@discussion
This function sets the blending mode of an evo/ebo object. It's not applied to group object.
@param obj
The graphics object.
@param blend
The blending mode enum.
@return bool
The operation for this evo/ebo is sucessful. If object is a group object or blend mode is not a legal one, it would return false.
*/
BOOL ElmSetBlend(ElmHandle obj, ELM_BLEND blend);
/*!
@abstract Set the solid fill color of an evo object.
@discussion
This function sets the solid fill color of an evo object.
@param evo
The evo object.
@param color
The uint32 color value in rgba order.
@return bool
The operation for this evo is sucessful. If the object is not a evo object, it would return false.
*/
BOOL ElmSetColor(ElmVecObj evo, uint32_t color);
/*!
@abstract Set the image paint fill of an evo.
@discussion
This function sets the image pattern for filling an evo. The image pattern
is a loaded ebo. The ebo's transformation is applied when drawing the evo.
@param evo
The evo object.
@param pattern
The image pattern to be set for the evo.
@return bool
The operation is successful or not.
*/
BOOL ElmSetPattern(ElmVecObj evo, ElmBitmapObj pattern);
/*!
@abstract Set the image paint fill of an evo.
@discussion
This function sets the image pattern for filling an evo. The image pattern
is a loaded ebo. The ebo's transformation is applied when drawing the evo.
@param evo
The evo object.
@param pattern
The image pattern to be set for the evo.
@return bool
The operation is successful or not.
*/
BOOL ElmSetPatternMode(ElmVecObj evo, ELM_PATTERN_MODE mode, uint32_t color);
/*!
@abstract Set the paint type of an evo.
@discussion
This function selects the paint type for evo to use. An evo may have 3 types
of paint: COLOR, PATTERN, and LINEAR GRADIENT. The Linear graident is always
a built-in resource, which can not be altered. If a binary resource doesn't
have built-in gradient paint resource, it can't be selected as the paint source.
Solid color is also a built-in attribute, but it can be changed by ElmSetColor().
Paint with a pattern always need an external ebo object, which is impossible
to be embedded in resource file,i.e. ebo object. Before select paint type to
be PATTERN, ElmSetPattern() must be called to attach an EBO to an EVO.
@param evo
The evo object.
@param type
The paint type to be set for the evo.
@return bool
The operation is successful or not.
If the corresponding type is not avaiable for the evo, it returns false and
type paint type falls back to COLOR.
*/
BOOL ElmSetPaintType(ElmVecObj evo, ELM_PAINT_TYPE type);
/*!
@abstract Create internal render buffer.
@discussion
This functiois is to create an internal render buffer for Elementary rendering, ussually it's not for direct display.
The buffer which is displayed on pannel is wrapped up by another API, whose address is managed by display controller side.
@param width
The buffer's width.
@param height
The buffer's height.
@param format
The buffer's format, check enumeration of ELM_BUFFER_FORMAT.
@return
The buffer handle.
*/
ElmBuffer ElmCreateBuffer(unsigned int width, unsigned int height, ELM_BUFFER_FORMAT format);
/*!
@abstract Wrap a customized buffer.
@discussion
The application may wrap a user created buffer by giving the information of
the buffer including the size, the memory addresses and format. E.g., the
application can wrap a system framebuffer thus ELM can directly render onto
the screen.
@return
The buffer handle.
*/
ElmBuffer ElmWrapBuffer(int width, int height, int stride,
void *logical, uint32_t physical,
ELM_BUFFER_FORMAT format);
/*!
@abstract Get buffer address.
@discussion
The function is to get the address of ElmBuffer.
@return
The buffer address.
*/
uint32_t ElmGetBufferAddress(ElmBuffer buffer);
/*!
@abstract Destroy a render buffer.
@discussion
This function is to release all internal resource inside Elementary libary belonging to this buffer.
Applicatoin need make sure the buffer is not being used by elmentary library any more when calling this function.
@param buffer
The render buffer handle
@return
If destroying is completed successfully.
*/
BOOL ElmDestroyBuffer(ElmBuffer buffer);
/*!
@abstract Save a buffer to PNG file.
@discussion
This function can save the buffer into a PNG file.
@param buffer
The render buffer handle.
@param name
The name of the PNG file to sve.
@return
Save OK or NOT.
*/
BOOL ElmSaveBuffer(ElmBuffer buffer, const char *name);
/*!
@abstract Clear a render buffer with specified color and dimension.
@discussion
This function is called to clear full or partial of the buffer. If the rectangle is out of buffer space, the intersect portion will be cleared.
@param buffer
A render buffer handle.
@param color
Clear color value.
@param x
x origin of partical clear rectangle.
@param y
y origin of partial clear rectangle.
@param width
width of partical clear rectangle.
@param height
height of partical clear rectangle.
@param full
Flag to indicate a full buffer clear. If true, the dimension parameters will be ignored.
@return bool
Indicate the clear operation is set up correctly.
*/
BOOL ElmClear(ElmBuffer buffer, uint32_t color, uint32_t x, uint32_t y, uint32_t width, uint32_t height, BOOL full);
/*!
@abstract Destroy an ELM object.
@discussion
This function is to release all internal resource inside Elementary libary belonging to this object.
Applicatoin need make sure the object is not being used by elmentary library any more when calling this function.
If an EBO is being destroyed and it's attached to one EVO, it need to guarantee that EVO is not being used by elementary library too.
@param object
The object handle
@return
If destroying is completed successfully.
*/
BOOL ElmDestroyObject(ElmHandle object);
/*!
@abstract Finish all rendering on GPU issued before this call.
@discussion
This function tells the engine that it has finished the frame data and GPU can draw it now. It's blocked until GPU rendering done.
@return
If the opeartion is successfully done or not.
*/
BOOL ElmFinish();
/*!
@abstract Flush all rendering command to GPU issued before this call.
@discussion
This function tells the engine to start kicking off command to GPU side, it will return immediately after firing off GPU.
@return
If the opeartion is successfully done or not.
*/
BOOL ElmFlush();
/*!
@abstract Query the paint color of an evo object.
*/
BOOL ElmGetColor(ElmVecObj evoHandle,uint32_t *color);
/*!
@abstract Query the vectory path count of an EGO object. If the given object
is an evo/ebo, the count is 0.
*/
uint32_t ElmGetVectorCount(ElmHandle handle);
/*!
@abstract Query the type of an object (by handle).
*/
ELM_OBJECT_TYPE ElmGetObjectType(ElmHandle handle);
/*!
@abstract Set the current vectory object index to operate on.
*/
BOOL ElmSetCurrentVector(int32_t id);
BOOL ElmScalePaint(ElmHandle handle, float sx, float sy);
BOOL ElmRotatePaint(ElmHandle handle, float degrees);
BOOL ElmTranslatePaint(ElmHandle handle, float tx, float ty);
/*!
@abstract Get handle of the framebuffer.
*/
ElmBuffer ElmGetBuffer(vg_lite_buffer_t *buffer);
#ifdef __cplusplus
}
#endif
#endif /* ELM_H_ */