| Tizen Native API
    9.0
    | 
Vector Graphics Object is the scene graph for managing vector graphics objects. User can create shape objects as well as fill objects and give them to the Evas_Object_Vg for drawing on the screen as well as managing the lifecycle of the objects, enabling reuse of shape objects.
Since Evas_Object_Vg is an Evas_Object all operations applicable to an Evas_Object can be performed on it (clipping, mapping, etc).
To create complex vector graphics you can create a hierarchy of shape and fill objects and give the hierarchy to Evas_Object which will be responsible for drawing and showing on the screen.
As the shape object and fill object (linear and radial gradients) have retain mode API, you only have to create it once and set the properties and give it to Evas_Object_Vg.
Any change in the properties of a shape or fill object are automatically notified to Evas_Object_Vg triggering a redraw to reflect the changes.
To create a vector path, you can give a list of path commands to the shape object using efl_gfx_shape_path_set() API.
Below are the list of features currently supported by Vector object.
- Drawing SVG Path. You can construct a path by using api in efl_gfx_utils.h
- Gradient filling and stroking. You can fill or stroke the path using linear or radial gradient. - See also:
- Evas_Vg_Gradient_Linear and Evas_Vg_Gradient_Radial
 
- Transformation support for path and gradient fill. You can apply affine transforms to path objects. - See also:
- Eina_Matrix.
 - Note:
- Below are the list of interfaces and classes that can be used to draw vector graphics using vector objects.
 
- Efl.Gfx.Shape
- Evas.VG_Shape
- Evas.VG_Node
- Efl.Gfx.Gradient
- Efl.Gfx.Gradient_Radial
- Efl.Gfx.Gradient_Linear
Example:
vector = evas_object_vg_add(canvas); root = evas_obj_vg_root_node_get(vector); shape = efl_add(EVAS_VG_SHAPE_CLASS, root); Efl_Gfx_Path_Command *path_cmd = NULL; double *points = NULL; efl_gfx_path_append_circle(&path_cmd, &points); * evas_vg_node_origin_set(shape, 10, 10); * efl_gfx_shape_stroke_width_set(shape, 1.0); * evas_vg_node_color_set(shape, 128, 128, 128, 80); * efl_gfx_shape_path_set(shape, path_cmd, points);
- Since (EFL) :
- 1.14
| Functions | |
| void | evas_object_vg_root_node_set (Evas_Object *obj, Evas_Vg_Node *root) | 
| Control how the viewbox is mapped to the vg canvas's viewport. | |
| Evas_Vg_Node * | evas_object_vg_root_node_get (const Evas_Object *obj) | 
| Get the root node of the evas_object_vg. | |
| Evas_Object * | evas_object_vg_add (Evas *e) | 
| Creates a new vector object on the given Evas ecanvas. | |
| Evas_Vg_Shape * | evas_vg_shape_add (Evas_Vg_Container *parent) | 
| Creates a new vector shape object. | |
| Evas_Vg_Container * | evas_vg_container_add (Evas_Object *parent) | 
| Creates a new vector container object. | |
| Eina_Bool | evas_vg_node_visible_get (Evas_Vg_Node *obj) | 
| Retrieves whether or not the given Evas_Vg_Node object is visible. | |
| void | evas_vg_node_visible_set (Evas_Vg_Node *obj, Eina_Bool v) | 
| Makes the given Evas_Vg_Node object visible or invisible. | |
| void | evas_vg_node_color_get (Evas_Vg_Node *obj, int *r, int *g, int *b, int *a) | 
| Retrieves the general/main color of the given Evas_Vg_Node object. | |
| void | evas_vg_node_color_set (Evas_Vg_Node *obj, int r, int g, int b, int a) | 
| Sets the general/main color of the given Evas_Vg_Node object to the given one. | |
| void | evas_vg_shape_stroke_color_get (Evas_Vg_Shape *obj, int *r, int *g, int *b, int *a) | 
| Retrieves the geometry of the given Evas_Vg_Node object. | |
| void | evas_vg_shape_stroke_color_set (Evas_Vg_Shape *obj, int r, int g, int b, int a) | 
| Sets the color to be used for stroking the path. | |
| double | evas_vg_shape_stroke_width_get (Evas_Vg_Shape *obj) | 
| Gets the stroke width to be used for stroking the path. | |
| void | evas_vg_shape_stroke_width_set (Evas_Vg_Shape *obj, double w) | 
| Sets the stroke width to be used for stroking the path. | |
| Evas_Vg_Cap | evas_vg_shape_stroke_cap_get (Evas_Vg_Shape *obj) | 
| Gets the stroke location to be used for stroking the path. | |
| void | evas_vg_shape_stroke_cap_set (Evas_Vg_Shape *obj, Evas_Vg_Cap c) | 
| Sets the cap style to be used for stroking the path. | |
| Evas_Vg_Join | evas_vg_shape_stroke_join_get (Evas_Vg_Shape *obj) | 
| Gets the join style used for stroking path. | |
| void | evas_vg_shape_stroke_join_set (Evas_Vg_Shape *obj, Evas_Vg_Join j) | 
| Sets the join style to be used for stroking the path. | |
| void | evas_vg_shape_path_set (Evas_Vg_Shape *obj, const Evas_Vg_Path_Command *op, const double *points) | 
| Sets the fill rule to be used. | |
| void | evas_vg_shape_path_get (Evas_Vg_Shape *obj, const Evas_Vg_Path_Command **op, const double **points) | 
| Gets the command and points list. | |
| void | evas_vg_shape_dup (Evas_Vg_Shape *obj, Evas_Vg_Shape *dup_from) | 
| Gets the command and points length. | |
| void | evas_vg_shape_reset (Evas_Vg_Shape *obj) | 
| Reset the shape data of the shape object. | |
| void | evas_vg_shape_append_move_to (Evas_Vg_Shape *obj, double x, double y) | 
| Moves the current point to the given point, implicitly starting a new subpath and closing the previous one. | |
| void | evas_vg_shape_append_line_to (Evas_Vg_Shape *obj, double x, double y) | 
| Adds a straight line from the current position to the given endPoint. After the line is drawn, the current position is updated to be at the end point of the line. | |
| void | evas_vg_shape_append_cubic_to (Evas_Vg_Shape *obj, double x, double y, double ctrl_x0, double ctrl_y0, double ctrl_x1, double ctrl_y1) | 
| Adds a quadratic Bezier curve between the current position and the given end point (x,y) using the control points specified by (ctrl_x, ctrl_y). After the path is drawn, the current position is updated to be at the end point of the path. | |
| void | evas_vg_shape_append_arc_to (Evas_Vg_Shape *obj, double x, double y, double rx, double ry, double angle, Eina_Bool large_arc, Eina_Bool sweep) | 
| Same as evas_vg_shape_append_cubic_to() api only difference is that it uses the current control point to draw the bezier. | |
| void | evas_vg_shape_append_arc (Evas_Vg_Shape *obj, double x, double y, double w, double h, double start_angle, double sweep_length) | 
| Append an arc that enclosed in the given rectangle (x, y, w, h). The angle is defined in counter clock wise , use -ve angle for clockwise arc. | |
| void | evas_vg_shape_append_close (Evas_Vg_Shape *obj) | 
| Closes the current subpath by drawing a line to the beginning of the subpath, automatically starting a new path. The current point of the new path is (0, 0). | |
| void | evas_vg_shape_append_circle (Evas_Vg_Shape *obj, double x, double y, double radius) | 
| Append a circle with given center and radius. | |
| void | evas_vg_shape_append_rect (Evas_Vg_Shape *obj, double x, double y, double w, double h, double rx, double ry) | 
| Append a ellipse with given center and x-radius, y-radius. | |
| void | evas_vg_shape_fill_set (Evas_Vg_Shape *obj, Evas_Vg_Node *f) | 
| Append the SVG path data. | |
| Evas_Vg_Node * | evas_vg_shape_fill_get (const Evas_Vg_Shape *obj) | 
| Returns the object that is set for the fill property. | |
| void | evas_vg_shape_stroke_fill_set (Evas_Vg_Shape *obj, Evas_Vg_Node *f) | 
| Set a vg object as the stroke fill property. | |
| Evas_Vg_Node * | evas_vg_shape_stroke_fill_get (const Evas_Vg_Shape *obj) | 
| Returns the object that is set for the stroke fill property. | |
| void | evas_vg_gradient_stop_set (Evas_Vg_Gradient *obj, const Evas_Vg_Gradient_Stop *colors, unsigned int length) | 
| Set the list of color stops for the gradient. | |
| void | evas_vg_gradient_stop_get (Evas_Vg_Gradient *obj, const Evas_Vg_Gradient_Stop **colors, unsigned int *length) | 
| Get the list of color stops. | |
| void | evas_vg_gradient_spread_set (Evas_Vg_Gradient *obj, Evas_Vg_Gradient_Spread s) | 
| Specifies the spread method that should be used for this gradient. | |
| Evas_Vg_Gradient_Spread | evas_vg_gradient_spread_get (Evas_Vg_Gradient *obj) | 
| Returns the spread method use by this gradient. The default is EVAS_VG_GRADIENT_SPREAD_PAD. | |
| Evas_Vg_Gradient_Linear * | evas_vg_gradient_linear_add (Evas_Vg_Container *parent) | 
| Creates a new linear gradient object. | |
| void | evas_vg_gradient_linear_start_set (Evas_Vg_Gradient_Linear *obj, double x, double y) | 
| Sets the start point of this linear gradient. | |
| void | evas_vg_gradient_linear_start_get (Evas_Vg_Gradient_Linear *obj, double *x, double *y) | 
| Gets the start point of this linear gradient. | |
| void | evas_vg_gradient_linear_end_set (Evas_Vg_Gradient_Linear *obj, double x, double y) | 
| Sets the end point of this linear gradient. | |
| void | evas_vg_gradient_linear_end_get (Evas_Vg_Gradient_Linear *obj, double *x, double *y) | 
| Gets the end point of this linear gradient. | |
| Evas_Vg_Gradient_Radial * | evas_vg_gradient_radial_add (Evas_Vg_Container *parent) | 
| Creates a new radial gradient object. | |
| void | evas_vg_gradient_radial_center_set (Evas_Vg_Gradient_Radial *obj, double x, double y) | 
| Sets the center of this radial gradient. | |
| void | evas_vg_gradient_radial_center_get (Evas_Vg_Gradient_Radial *obj, double *x, double *y) | 
| Gets the center of this radial gradient. | |
| void | evas_vg_gradient_radial_radius_set (Evas_Vg_Gradient_Radial *obj, double r) | 
| Sets the center radius of this radial gradient. | |
| double | evas_vg_gradient_radial_radius_get (Evas_Vg_Gradient_Radial *obj) | 
| Gets the center radius of this radial gradient. | |
| void | evas_vg_gradient_radial_focal_set (Evas_Vg_Gradient_Radial *obj, double x, double y) | 
| Sets the focal point of this radial gradient. | |
| void | evas_vg_gradient_radial_focal_get (Evas_Vg_Gradient_Radial *obj, double *x, double *y) | 
| Gets the focal point of this radial gradient. | |
| Typedefs | |
| typedef enum Evas_Vg_Cap_Type | Evas_Vg_Cap | 
| These values determine how the end of opened sub-paths are rendered in a stroke. evas_vg_shape_stroke_cap_set. | |
| typedef enum Evas_Vg_Join_Type | Evas_Vg_Join | 
| These values determine how two joining lines are rendered in a stroker. evas_vg_shape_stroke_join_set. | |
| typedef enum Evas_Vg_Path_Command_Type | Evas_Vg_Path_Command | 
| These values determine how the points are interpreted in a stream of points. | |
| typedef struct _Evas_Vg_Gradient_Stop | Evas_Vg_Gradient_Stop | 
| Type defining gradient stops. Describes the location and color of a transition point in a gradient. | |
| typedef enum Evas_Vg_Gradient_Spread_Type | Evas_Vg_Gradient_Spread | 
| Specifies how the area outside the gradient area should be filled. evas_vg_gradient_spread_set. | |
| typedef enum Evas_Vg_Fill_Rule_Type | Evas_Vg_Fill_Rule | 
| Specifies how an image content get filled. evas_vg_shape_fill_rule_set. | |
| typedef struct _Evas_Vg_Dash | Evas_Vg_Dash | 
| Type describing dash. evas_vg_shape_stroke_dash_set. | |
Typedef Documentation
| typedef enum Evas_Vg_Cap_Type Evas_Vg_Cap | 
These values determine how the end of opened sub-paths are rendered in a stroke. evas_vg_shape_stroke_cap_set.
Get the total number of frames of the vector, if it's animated.
- Returns:
- The number of frames. 0, if it's not animated.
- Since (EFL) :
- 1.23 Get the duration of a sequence of frames.
This returns total duration in seconds that the specified sequence of frames should take.
If start_frame is 1 and frame_num is 0, this returns the duration of frame 1. If start_frame is 1 and frame_num is 1, this returns the total duration of frame 1 + frame 2.
- Parameters:
- 
  [in] start_frame The first frame, ranges from 1 to maximum frame count. [in] frame_num Number of frames in the sequence, starts from 0. 
- Returns:
- Duration in seconds.
- See also:
- evas_object_vg_animated_frame_count_get()
- Since (EFL) :
- 1.23
Set the source file from where an vector object must fetch the real vector data (it may be one of json, svg, eet files).
If the file supports multiple data stored in it (as Eet files do), you can specify the key to be used as the index of the vector in this file.
- Parameters:
- 
  [in] file The vector file path. [in] key The vector key in file(if its an Eet one), orNULL, otherwise.
- Returns:
- EINA_TRUEif it's succeed to read file,- EINA_FALSEotherwise.
- Since (EFL) :
- 1.23 Set current frame of animated vector object.
- Parameters:
- 
  [in] frame_index The index of current frame. 
- Note:
- the frame_indexmust be in range of animation frames. (0 ~ max frame count)
- Returns:
- EINA_TRUE, if the frame index is valid.- EINA_FALSE, otherwise.
- See also:
- evas_object_vg_animated_frame_count_get()
- Since (EFL) :
- 1.23 Get the current frame number of animated vector object.
- Returns:
- The frame index.
- See also:
- evas_object_vg_animated_frame_set()
- evas_object_vg_animated_frame_count_get()
- Since (EFL) :
- 1.23
- Since (EFL) :
- 1.24
| typedef struct _Evas_Vg_Dash Evas_Vg_Dash | 
Type describing dash. evas_vg_shape_stroke_dash_set.
- Since (EFL) :
- 1.24
| typedef enum Evas_Vg_Fill_Rule_Type Evas_Vg_Fill_Rule | 
Specifies how an image content get filled. evas_vg_shape_fill_rule_set.
- Since (EFL) :
- 1.25.1
| typedef enum Evas_Vg_Gradient_Spread_Type Evas_Vg_Gradient_Spread | 
Specifies how the area outside the gradient area should be filled. evas_vg_gradient_spread_set.
- Since (EFL) :
- 1.24
| typedef struct _Evas_Vg_Gradient_Stop Evas_Vg_Gradient_Stop | 
Type defining gradient stops. Describes the location and color of a transition point in a gradient.
- Since (EFL) :
- 1.24
| typedef enum Evas_Vg_Join_Type Evas_Vg_Join | 
These values determine how two joining lines are rendered in a stroker. evas_vg_shape_stroke_join_set.
- Since (EFL) :
- 1.24
| typedef enum Evas_Vg_Path_Command_Type Evas_Vg_Path_Command | 
These values determine how the points are interpreted in a stream of points.
- Since (EFL) :
- 1.24
Enumeration Type Documentation
Enumeration that defines how viewbox will be filled int the vg canvs's viewport. default Fill_Mode is none. 
- Since (EFL) :
- 1.24
- Enumerator:
| enum Evas_Vg_Cap_Type | 
These values determine how the end of opened sub-paths are rendered in a stroke. evas_vg_shape_stroke_cap_set.
Get the total number of frames of the vector, if it's animated.
- Returns:
- The number of frames. 0, if it's not animated.
- Since (EFL) :
- 1.23 Get the duration of a sequence of frames.
This returns total duration in seconds that the specified sequence of frames should take.
If start_frame is 1 and frame_num is 0, this returns the duration of frame 1. If start_frame is 1 and frame_num is 1, this returns the total duration of frame 1 + frame 2.
- Parameters:
- 
  [in] start_frame The first frame, ranges from 1 to maximum frame count. [in] frame_num Number of frames in the sequence, starts from 0. 
- Returns:
- Duration in seconds.
- See also:
- evas_object_vg_animated_frame_count_get()
- Since (EFL) :
- 1.23
Set the source file from where an vector object must fetch the real vector data (it may be one of json, svg, eet files).
If the file supports multiple data stored in it (as Eet files do), you can specify the key to be used as the index of the vector in this file.
- Parameters:
- 
  [in] file The vector file path. [in] key The vector key in file(if its an Eet one), orNULL, otherwise.
- Returns:
- EINA_TRUEif it's succeed to read file,- EINA_FALSEotherwise.
- Since (EFL) :
- 1.23 Set current frame of animated vector object.
- Parameters:
- 
  [in] frame_index The index of current frame. 
- Note:
- the frame_indexmust be in range of animation frames. (0 ~ max frame count)
- Returns:
- EINA_TRUE, if the frame index is valid.- EINA_FALSE, otherwise.
- See also:
- evas_object_vg_animated_frame_count_get()
- Since (EFL) :
- 1.23 Get the current frame number of animated vector object.
- Returns:
- The frame index.
- See also:
- evas_object_vg_animated_frame_set()
- evas_object_vg_animated_frame_count_get()
- Since (EFL) :
- 1.23
- Since (EFL) :
- 1.24
- Enumerator:
Specifies how an image content get filled. evas_vg_shape_fill_rule_set.
- Since (EFL) :
- 1.25.1
- Enumerator:
Specifies how the area outside the gradient area should be filled. evas_vg_gradient_spread_set.
- Since (EFL) :
- 1.24
- Enumerator:
| enum Evas_Vg_Join_Type | 
These values determine how two joining lines are rendered in a stroker. evas_vg_shape_stroke_join_set.
- Since (EFL) :
- 1.24
- Enumerator:
These values determine how the points are interpreted in a stream of points.
- Since (EFL) :
- 1.24
- Enumerator:
Function Documentation
| Evas_Object* evas_object_vg_add | ( | Evas * | e | ) | 
Creates a new vector object on the given Evas e canvas. 
The shape object hierarchy can be added to the evas_object_vg by accessing the root node of the vg canvas and adding the hierarchy as child to the root node.
- Parameters:
- 
  [in] e The given canvas. 
- Returns:
- The created vector object handle.
- See also:
- evas_obj_vg_root_node_get()
- Since (EFL) :
- 1.14
- Since :
- 3.0
| Evas_Vg_Node* evas_object_vg_root_node_get | ( | const Evas_Object * | obj | ) | 
Get the root node of the evas_object_vg.
- Parameters:
- 
  [in] obj The object. 
- Returns:
- Root node of the VG canvas.
- Since (EFL) :
- 1.14
- Since :
- 3.0
| void evas_object_vg_root_node_set | ( | Evas_Object * | obj, | 
| Evas_Vg_Node * | root | ||
| ) | 
Control how the viewbox is mapped to the vg canvas's viewport.
- Parameters:
- 
  [in] obj The object. [in] fill_mode Fill mode type 
- Since (EFL) :
- 1.24 Control how the viewbox is mapped to the vg canvas's viewport.
- Parameters:
- 
  [in] obj The object. 
- Returns:
- Fill mode type
- Since (EFL) :
- 1.24 Sets the viewbox for the evas vg canvas. viewbox if set should be mapped to the canvas geometry when rendering the vg tree.
- Parameters:
- 
  [in] obj The object. [in] viewbox viewbox for the vg canvas 
- Since (EFL) :
- 1.24 Get the current viewbox from the evas_object_vg
- Parameters:
- 
  [in] obj The object. 
- Returns:
- viewbox for the vg canvas
- Since (EFL) :
- 1.24 Control how the viewbox is positioned inside the viewport.
- Parameters:
- 
  [in] obj The object. [in] align_x Alignment in the horizontal axis (0 <= align_x <= 1). [in] align_y Alignment in the vertical axis (0 <= align_y <= 1). 
- Since (EFL) :
- 1.24 Control how the viewbox is positioned inside the viewport.
- Parameters:
- 
  [in] obj The object. [out] align_x Alignment in the horizontal axis (0 <= align_x <= 1). [out] align_y Alignment in the vertical axis (0 <= align_y <= 1). 
- Since (EFL) :
- 1.24 Set the root node of the evas_object_vg.
- Note:
- To manually create the shape object and show in the Vg object canvas you must create the hierarchy and set as root node.
It takes the ownership of the root node.
- Parameters:
- 
  [in] obj The object. [in] root Root node(Evas_Vg_Container) of the VG canvas. 
- Since (EFL) :
- 1.24
- Since :
- 6.0
| Evas_Vg_Container* evas_vg_container_add | ( | Evas_Object * | parent | ) | 
Creates a new vector container object.
- Parameters:
- 
  [in] parent The given vector container object. 
- Returns:
- The created vector container object handle.
- Since (EFL) :
- 1.14
- Since :
- 3.0
| Evas_Vg_Gradient_Linear* evas_vg_gradient_linear_add | ( | Evas_Vg_Container * | parent | ) | 
Creates a new linear gradient object.
- Parameters:
- 
  [in] parent The given vector container object. 
- Returns:
- The created linear gradient object handle.
- Since (EFL) :
- 1.24
- Since :
- 6.0
| void evas_vg_gradient_linear_end_get | ( | Evas_Vg_Gradient_Linear * | obj, | 
| double * | x, | ||
| double * | y | ||
| ) | 
Gets the end point of this linear gradient.
- Parameters:
- 
  [in] obj The object. [out] x The x co-ordinate of end point. [out] y The y co-ordinate of end point. 
- Since (EFL) :
- 1.24
- Since :
- 3.0
| void evas_vg_gradient_linear_end_set | ( | Evas_Vg_Gradient_Linear * | obj, | 
| double | x, | ||
| double | y | ||
| ) | 
Sets the end point of this linear gradient.
- Parameters:
- 
  [in] obj The object. [in] x The x co-ordinate of end point. [in] y The y co-ordinate of end point. 
- Since (EFL) :
- 1.24
- Since :
- 3.0
| void evas_vg_gradient_linear_start_get | ( | Evas_Vg_Gradient_Linear * | obj, | 
| double * | x, | ||
| double * | y | ||
| ) | 
Gets the start point of this linear gradient.
- Parameters:
- 
  [in] obj The object. [out] x The x co-ordinate of start point. [out] y The y co-ordinate of start point. 
- Since (EFL) :
- 1.24
- Since :
- 3.0
| void evas_vg_gradient_linear_start_set | ( | Evas_Vg_Gradient_Linear * | obj, | 
| double | x, | ||
| double | y | ||
| ) | 
Sets the start point of this linear gradient.
- Parameters:
- 
  [in] obj The object. [in] x The x co-ordinate of start point. [in] y The y co-ordinate of start point 
- Since (EFL) :
- 1.24
- Since :
- 3.0
| Evas_Vg_Gradient_Radial* evas_vg_gradient_radial_add | ( | Evas_Vg_Container * | parent | ) | 
Creates a new radial gradient object.
- Parameters:
- 
  [in] parent The given vector container object. 
- Returns:
- The created radial gradient object handle.
- Since (EFL) :
- 1.24
- Since :
- 6.0
| void evas_vg_gradient_radial_center_get | ( | Evas_Vg_Gradient_Radial * | obj, | 
| double * | x, | ||
| double * | y | ||
| ) | 
Gets the center of this radial gradient.
- Parameters:
- 
  [in] obj The object. [out] x The x co-ordinate of center point. [out] y The y co-ordinate of center point. 
- Since (EFL) :
- 1.24
- Since :
- 3.0
| void evas_vg_gradient_radial_center_set | ( | Evas_Vg_Gradient_Radial * | obj, | 
| double | x, | ||
| double | y | ||
| ) | 
Sets the center of this radial gradient.
- Parameters:
- 
  [in] obj The object. [in] x The x co-ordinate of center point. [in] y The y co-ordinate of center point. 
- Since (EFL) :
- 1.24
- Since :
- 3.0
| void evas_vg_gradient_radial_focal_get | ( | Evas_Vg_Gradient_Radial * | obj, | 
| double * | x, | ||
| double * | y | ||
| ) | 
Gets the focal point of this radial gradient.
- Parameters:
- 
  [in] obj The object. [out] x The x co-ordinate of focal point. [out] y The y co-ordinate of focal point. 
- Since (EFL) :
- 1.24
- Since :
- 3.0
| void evas_vg_gradient_radial_focal_set | ( | Evas_Vg_Gradient_Radial * | obj, | 
| double | x, | ||
| double | y | ||
| ) | 
Sets the focal point of this radial gradient.
- Parameters:
- 
  [in] obj The object. [in] x The x co-ordinate of focal point. [in] y The y co-ordinate of focal point. 
- Since (EFL) :
- 1.24
- Since :
- 3.0
| double evas_vg_gradient_radial_radius_get | ( | Evas_Vg_Gradient_Radial * | obj | ) | 
Gets the center radius of this radial gradient.
- Parameters:
- 
  [in] obj The object. 
- Returns:
- The center radius of the given object.
- Since (EFL) :
- 1.24
- Since :
- 3.0
| void evas_vg_gradient_radial_radius_set | ( | Evas_Vg_Gradient_Radial * | obj, | 
| double | r | ||
| ) | 
Sets the center radius of this radial gradient.
- Parameters:
- 
  [in] obj The object. [in] r The center radius. 
- Since (EFL) :
- 1.24
- Since :
- 3.0
| Evas_Vg_Gradient_Spread evas_vg_gradient_spread_get | ( | Evas_Vg_Gradient * | obj | ) | 
Returns the spread method use by this gradient. The default is EVAS_VG_GRADIENT_SPREAD_PAD.
- Parameters:
- 
  [in] obj The object. 
- Returns:
- The spread type of the given object.
- Since (EFL) :
- 1.14
- Since :
- 3.0
| void evas_vg_gradient_spread_set | ( | Evas_Vg_Gradient * | obj, | 
| Evas_Vg_Gradient_Spread | s | ||
| ) | 
Specifies the spread method that should be used for this gradient.
- Parameters:
- 
  [in] obj The object. [in] s The spread type to be used. 
- Since (EFL) :
- 1.14
- Since :
- 3.0
| void evas_vg_gradient_stop_get | ( | Evas_Vg_Gradient * | obj, | 
| const Evas_Vg_Gradient_Stop ** | colors, | ||
| unsigned int * | length | ||
| ) | 
Get the list of color stops.
- Parameters:
- 
  [in] obj The object. [out] colors The color stops list. [out] length The length of the list. 
- Since (EFL) :
- 1.14
- Since :
- 3.0
| void evas_vg_gradient_stop_set | ( | Evas_Vg_Gradient * | obj, | 
| const Evas_Vg_Gradient_Stop * | colors, | ||
| unsigned int | length | ||
| ) | 
Set the list of color stops for the gradient.
- Parameters:
- 
  [in] obj The object. [in] colors The color stops list. [in] length The length of the list. 
- Since (EFL) :
- 1.14
- Since :
- 3.0
| void evas_vg_node_color_get | ( | Evas_Vg_Node * | obj, | 
| int * | r, | ||
| int * | g, | ||
| int * | b, | ||
| int * | a | ||
| ) | 
Retrieves the general/main color of the given Evas_Vg_Node object.
Retrieves the āmainā color's RGB component (and alpha channel) values, which range from 0 to 255. For the alpha channel, which defines the object's transparency level, 0 means totally transparent, while 255 means opaque. These color values are premultiplied by the alpha value.
- Note:
- Use NULLpointers on the components you're not interested in: they'll be ignored by the function.
- Parameters:
- 
  [in] obj The object. [out] r The red component of the given color. [out] g The green component of the given color. [out] b The blue component of the given color. [out] a The alpha component of the given color. 
- Since (EFL) :
- 1.24
- Since :
- 3.0
| void evas_vg_node_color_set | ( | Evas_Vg_Node * | obj, | 
| int | r, | ||
| int | g, | ||
| int | b, | ||
| int | a | ||
| ) | 
Sets the general/main color of the given Evas_Vg_Node object to the given one.
- See also:
- evas_vg_node_color_get() (for an example)
- Note:
- These color values are expected to be premultiplied by a.
- Parameters:
- 
  [in] obj The object. [in] r The red component of the given color. [in] g The green component of the given color. [in] b The blue component of the given color. [in] a The alpha component of the given color. 
- Since (EFL) :
- 1.24
- Since :
- 3.0
| Eina_Bool evas_vg_node_visible_get | ( | Evas_Vg_Node * | obj | ) | 
Retrieves whether or not the given Evas_Vg_Node object is visible.
- Parameters:
- 
  [in] obj The object. 
- Returns:
- EINA_TRUEif the object is visible,- EINA_FALSEotherwise.
- Since (EFL) :
- 1.24
- Since :
- 3.0
| void evas_vg_node_visible_set | ( | Evas_Vg_Node * | obj, | 
| Eina_Bool | v | ||
| ) | 
Makes the given Evas_Vg_Node object visible or invisible.
- Parameters:
- 
  [in] obj The object. [in] v EINA_TRUEif to make the object visible,EINA_FALSEotherwise.
- Since (EFL) :
- 1.24
- Since :
- 3.0
| Evas_Vg_Shape* evas_vg_shape_add | ( | Evas_Vg_Container * | parent | ) | 
Creates a new vector shape object.
- Parameters:
- 
  [in] parent The given vector container object. 
- Returns:
- The created vector shape object handle.
- Since (EFL) :
- 1.14
- Since :
- 3.0
| void evas_vg_shape_append_arc | ( | Evas_Vg_Shape * | obj, | 
| double | x, | ||
| double | y, | ||
| double | w, | ||
| double | h, | ||
| double | start_angle, | ||
| double | sweep_length | ||
| ) | 
Append an arc that enclosed in the given rectangle (x, y, w, h). The angle is defined in counter clock wise , use -ve angle for clockwise arc.
- Parameters:
- 
  [in] obj The object. [in] y The x co-ordinate of the rect. [in] y The y co-ordinate of the rect. [in] w The width of the rect. [in] h The height of the rect. [in] start_angle The angle at which the arc will start. [in] sweep_length The length of the arc. 
- Since (EFL) :
- 1.18
- Since :
- 6.0
| void evas_vg_shape_append_arc_to | ( | Evas_Vg_Shape * | obj, | 
| double | x, | ||
| double | y, | ||
| double | rx, | ||
| double | ry, | ||
| double | angle, | ||
| Eina_Bool | large_arc, | ||
| Eina_Bool | sweep | ||
| ) | 
Same as evas_vg_shape_append_cubic_to() api only difference is that it uses the current control point to draw the bezier.
- See also:
- evas_vg_shape_append_cubic_to()
- Parameters:
- 
  [in] obj The object. [in] x The x co-ordinate of end point of the line. [in] y The x co-ordinate of end point of the line. [in] ctrl_x The x co-ordinate of 2nd control point. [in] ctrl_y The y co-ordinate of 2nd control point. 
- Since (EFL) :
- 1.14 Append an arc that connects from the current point int the point list to the given point (x,y). The arc is defined by the given radius in x-direction (rx) and radius in y direction (ry).
- Note:
- Use this api if you know the end point's of the arc otherwise use more convenient function evas_vg_shape_append_arc_to()
- See also:
- evas_vg_shape_append_arc_to()
- Parameters:
- 
  [in] obj The object. [in] x The x co-ordinate of end point of the arc. [in] y The y co-ordinate of end point of the arc. [in] rx The radius of arc in x direction. [in] ry The radius of arc in y direction. [in] angle The x-axis rotation , normally 0. [in] large_arc Defines whether to draw the larger arc or smaller arc joining two point. [in] sweep Defines whether the arc will be drawn counter-clockwise or clockwise from current point to the end point taking into account the large_arc property. 
- Since (EFL) :
- 1.14
- Since :
- 6.0
| void evas_vg_shape_append_circle | ( | Evas_Vg_Shape * | obj, | 
| double | x, | ||
| double | y, | ||
| double | radius | ||
| ) | 
Append a circle with given center and radius.
- See also:
- evas_vg_shape_append_arc()
- Parameters:
- 
  [in] obj The object. [in] x The x co-ordinate of the center of the circle. [in] y The y co-ordinate of the center of the circle. [in] radius The radius of the circle. 
- Since (EFL) :
- 1.14
- Since :
- 6.0
| void evas_vg_shape_append_close | ( | Evas_Vg_Shape * | obj | ) | 
Closes the current subpath by drawing a line to the beginning of the subpath, automatically starting a new path. The current point of the new path is (0, 0).
- Note:
- If the subpath does not contain any points, this function does nothing.
- Parameters:
- 
  [in] obj The object. 
- Since (EFL) :
- 1.14
- Since :
- 6.0
| void evas_vg_shape_append_cubic_to | ( | Evas_Vg_Shape * | obj, | 
| double | x, | ||
| double | y, | ||
| double | ctrl_x0, | ||
| double | ctrl_y0, | ||
| double | ctrl_x1, | ||
| double | ctrl_y1 | ||
| ) | 
Adds a quadratic Bezier curve between the current position and the given end point (x,y) using the control points specified by (ctrl_x, ctrl_y). After the path is drawn, the current position is updated to be at the end point of the path.
- Parameters:
- 
  [in] obj The object. [in] x The x co-ordinate of end point of the line. [in] y The y co-ordinate of end point of the line. [in] ctrl_x The x co-ordinate of control point. [in] ctrl_y The y co-ordinate of control point. 
- Since (EFL) :
- 1.14 Same as evas_vg_shape_append_quadratic_to() api only difference is that it uses the current control point to draw the bezier.
- See also:
- evas_vg_shape_append_quadratic_to()
- Parameters:
- 
  [in] obj The object. [in] x The x co-ordinate of end point of the line. [in] y The y co-ordinate of end point of the line. 
- Since (EFL) :
- 1.14 Adds a cubic Bezier curve between the current position and the given end point (x,y) using the control points specified by (ctrl_x0, ctrl_y0), and (ctrl_x1, ctrl_y1). After the path is drawn, the current position is updated to be at the end point of the path.
- Parameters:
- 
  [in] obj The object. [in] x The x co-ordinate of end point of the line. [in] y The y co-ordinate of end point of the line. [in] ctrl_x0 The x co-ordinate of 1st control point. [in] ctrl_y0 The y co-ordinate of 1st control point. [in] ctrl_x1 The x co-ordinate of 2nd control point. [in] ctrl_y1 The y co-ordinate of 2nd control point. 
- Since (EFL) :
- 1.14
- Since :
- 6.0
| void evas_vg_shape_append_line_to | ( | Evas_Vg_Shape * | obj, | 
| double | x, | ||
| double | y | ||
| ) | 
Adds a straight line from the current position to the given endPoint. After the line is drawn, the current position is updated to be at the end point of the line.
- Note:
- if no current position present, it draws a line to itself, basically a point.
- See also:
- evas_vg_shape_append_move_to()
- Parameters:
- 
  [in] obj The object. [in] x The x co-ordinate of end point of the line. [in] y The y co-ordinate of end point of the line. 
- Since (EFL) :
- 1.14
- Since :
- 6.0
| void evas_vg_shape_append_move_to | ( | Evas_Vg_Shape * | obj, | 
| double | x, | ||
| double | y | ||
| ) | 
Moves the current point to the given point, implicitly starting a new subpath and closing the previous one.
- See also:
- evas_vg_shape_append_close()
- Parameters:
- 
  [in] obj The object. [in] x The x co-ordinate of the current point. [in] y The y co-ordinate of the current point. 
- Since (EFL) :
- 1.14
- Since :
- 6.0
| void evas_vg_shape_append_rect | ( | Evas_Vg_Shape * | obj, | 
| double | x, | ||
| double | y, | ||
| double | w, | ||
| double | h, | ||
| double | rx, | ||
| double | ry | ||
| ) | 
Append a ellipse with given center and x-radius, y-radius.
- Parameters:
- 
  [in] obj The object. [in] cx The x co-ordinate of the center of the ellipse. [in] cy The y co-ordinate of the center of the ellipse. [in] rx The horizontal radius of the ellipse [in] ry The vertical radius of the ellipse [in] radius The radius of the circle. 
- Since (EFL) :
- 1.25 Append the given rectangle with rounded corner to the path.
The xr and yr arguments specify the radii of the ellipses defining the corners of the rounded rectangle.
- Note:
- xr and yr are specified in terms of width and height respectively.
- if xr and yr are 0, then it will draw a rectangle without rounded corner.
- Parameters:
- 
  [in] obj The object. [in] x The x co-ordinate of the rectangle. [in] y The y co-ordinate of the rectangle. [in] w The width of the rectangle. [in] h The height of the rectangle. [in] rx The x radius of the rounded corner and should be in range [0 to w/2]. [in] ry The y radius of the rounded corner and should be in range [0 to h/2]. 
- Since (EFL) :
- 1.14
- Since :
- 6.0
| void evas_vg_shape_dup | ( | Evas_Vg_Shape * | obj, | 
| Evas_Vg_Shape * | dup_from | ||
| ) | 
Gets the command and points length.
- Parameters:
- 
  [in] obj The object. [out] commands The command length. [out] points The points length. 
- Since (EFL) :
- 1.14 Gets the current points.
- Parameters:
- 
  [in] obj The object. [out] x The x co-ordinate of current point. [out] y The y co-ordinate of current point. 
- Since (EFL) :
- 1.14 Gets the current control points.
- Parameters:
- 
  [in] obj The object. [out] x The x co-ordinate of control point. [out] y The y co-ordinate of control point. 
- Since (EFL) :
- 1.14 Copy the shape data from the object specified.
- Parameters:
- 
  [in] obj The object. [in] dup_from The Shape object from where data will be copied. 
- Since (EFL) :
- 1.14
- Since :
- 6.0
| Evas_Vg_Node* evas_vg_shape_fill_get | ( | const Evas_Vg_Shape * | obj | ) | 
Returns the object that is set for the fill property.
- Parameters:
- 
  [in] obj The object whose fill property is inspected. 
- Returns:
- The object that is set as fill property.
- Since (EFL) :
- 1.24
- Since :
- 3.0
| void evas_vg_shape_fill_set | ( | Evas_Vg_Shape * | obj, | 
| Evas_Vg_Node * | f | ||
| ) | 
Append the SVG path data.
- Parameters:
- 
  [in] obj The object. [in] svg_path_data The svg path data to append. 
- Since (EFL) :
- 1.24 Creates intermediary path part-way between two paths
Sets the points of the obj as the linear interpolation of the points in the from and to paths. The path's x,y position and control point coordinates are likewise interpolated.
The from and to paths must not already have equivalent points, and to must contain at least as many points as from, else the function returns false with no interpolation performed. If to has more points than from, the excess points are ignored.
- Parameters:
- 
  [in] obj The object. [in] from The source path. [in] to The destination path. [in] pos_map The position map in range 0.0 to 1.0. 
- Since (EFL) :
- 1.24 Check if the given objects have equal commands.
- Parameters:
- 
  [in] obj The object. [in] with The target object. 
- Returns:
- True on equal, falseotherwise.
- Since (EFL) :
- 1.24 Set a vg object as the fill property.
- Parameters:
- 
  [in] obj The object whose fill property gets modified. [in] f The object content to be used for filling. 
- Since (EFL) :
- 1.24
- Since :
- 3.0
| void evas_vg_shape_path_get | ( | Evas_Vg_Shape * | obj, | 
| const Evas_Vg_Path_Command ** | op, | ||
| const double ** | points | ||
| ) | 
Gets the command and points list.
- Parameters:
- 
  [in] obj The object. [out] op The command list. [out] points The point list. 
- Since (EFL) :
- 1.14
- Since :
- 6.0
| void evas_vg_shape_path_set | ( | Evas_Vg_Shape * | obj, | 
| const Evas_Vg_Path_Command * | op, | ||
| const double * | points | ||
| ) | 
Sets the fill rule to be used.
- Parameters:
- 
  [in] obj The object. [in] r The fill rule to use, default is EVAS_VG_FILL_RULE_WINDING. 
- Since (EFL) :
- 1.25.1 Gets the fill rule.
- Parameters:
- 
  [in] obj object. [out] r The fill rule to use. 
- Since (EFL) :
- 1.25.1 Set the list of commands and points to be used to create the content of shape.
- See also:
- Evas_Vg_Path_Command
- Parameters:
- 
  [in] obj The object. [in] op The command list. [in] points The point list. 
- Since (EFL) :
- 1.14
- Since :
- 6.0
| void evas_vg_shape_reset | ( | Evas_Vg_Shape * | obj | ) | 
Reset the shape data of the shape object.
- Parameters:
- 
  [in] obj The object. 
- Since (EFL) :
- 1.14
- Since :
- 6.0
| Evas_Vg_Cap evas_vg_shape_stroke_cap_get | ( | Evas_Vg_Shape * | obj | ) | 
Gets the stroke location to be used for stroking the path.
- Parameters:
- 
  [in] obj The object. 
- Returns:
- The stroke location.
- Since (EFL) :
- 1.24 Sets the stroke location to be used for stroking the path.
- Parameters:
- 
  [in] obj The object. [in] centered The stroke location. 
- Since (EFL) :
- 1.24 Gets the stroke dash type used for stroking path.
- Parameters:
- 
  [in] obj The object. [out] dash The dash types. [out] length The length of dash types. 
- Since (EFL) :
- 1.24 Sets the stroke dash type to be used for stroking the path.
- Parameters:
- 
  [in] obj The object. [in] dash The dash types. [in] length The length of dash types. 
- Since (EFL) :
- 1.24 Gets the cap style used for stroking path.
- Parameters:
- 
  [in] obj The object. 
- Returns:
- The cap style of the given object.
- Since (EFL) :
- 1.14
- Since :
- 3.0
| void evas_vg_shape_stroke_cap_set | ( | Evas_Vg_Shape * | obj, | 
| Evas_Vg_Cap | c | ||
| ) | 
Sets the cap style to be used for stroking the path.
The cap will be used for capping the end point of a open subpath.
- See also:
- Evas_Vg_Cap
- Parameters:
- 
  [in] obj The object. [in] c The cap style to use , default is EVAS_VG_CAP_BUTT 
- Since (EFL) :
- 1.14
- Since :
- 3.0
| void evas_vg_shape_stroke_color_get | ( | Evas_Vg_Shape * | obj, | 
| int * | r, | ||
| int * | g, | ||
| int * | b, | ||
| int * | a | ||
| ) | 
Retrieves the geometry of the given Evas_Vg_Node object.
- Parameters:
- 
  [in] obj The object. [out] x The x geometry of the given object. [out] y The y geometry of the given object. [out] w The w geometry of the given object. [out] h The h geometry of the given object. 
- Since (EFL) :
- 1.24 Changes the geometry of the given Evas_Vg_Node object.
- Parameters:
- 
  [in] obj The object. [in] x The x geometry of the given object. [in] y The y geometry of the given object. [in] w The w geometry of the given object. [in] h The h geometry of the given object. 
- Since (EFL) :
- 1.24
Stack obj immediately below below.
Objects, in a given canvas, are stacked in the order they get added to it. This means that, if they overlap, the highest ones will cover the lowest ones, in that order. This function is a way to change the stacking order for the objects.
This function is intended to be used with objects belonging to the same layer in a given canvas, otherwise it will fail (and accomplish nothing).
If you have smart objects on your canvas and obj is a member of one of them, then below must also be a member of the same smart object.
Similarly, if obj is not a member of a smart object, below must not be either.
- Parameters:
- 
  [in] obj The object. [in] below The object below which to stackļ¼ 
- Since (EFL) :
- 1.24 Stack objimmediately aboveabove.
Objects, in a given canvas, are stacked in the order they get added to it. This means that, if they overlap, the highest ones will cover the lowest ones, in that order. This function is a way to change the stacking order for the objects.
This function is intended to be used with objects belonging to the same layer in a given canvas, otherwise it will fail (and accomplish nothing).
If you have smart objects on your canvas and obj is a member of one of them, then above must also be a member of the same smart object.
Similarly, if obj is not a member of a smart object, above must not be either.
- Parameters:
- 
  [in] obj The object. [in] above The object above which to stack. 
- Since (EFL) :
- 1.24 Raise objto the top of its layer.
obj will, then, be the highest one in the layer it belongs to. Object on other layers won't get touched.
- Parameters:
- 
  [in] obj The object. 
- Since (EFL) :
- 1.24 Lower objto the bottom of its layer.
obj will, then, be the lowest one in the layer it belongs to. Objects on other layers won't get touched.
- Parameters:
- 
  [in] obj The object. 
- Since (EFL) :
- 1.24 Get the stroke scaling factor used for stroking this path.
- Parameters:
- 
  [in] obj The object. 
- Returns:
- The stroke scale of the given object.
- Since (EFL) :
- 1.14 Sets the stroke scale to be used for stroking the path. the scale property will be used along with stroke width property.
- Parameters:
- 
  [in] obj The object. [in] s The stroke scale value. 
- Since (EFL) :
- 1.14 Gets the color used for stroking the path.
- Parameters:
- 
  [in] obj The object. [out] r The red component of the given color. [out] g The green component of the given color. [out] b The blue component of the given color. [out] a The alpha component of the given color. 
- Since (EFL) :
- 1.14
- Since :
- 3.0
| void evas_vg_shape_stroke_color_set | ( | Evas_Vg_Shape * | obj, | 
| int | r, | ||
| int | g, | ||
| int | b, | ||
| int | a | ||
| ) | 
Sets the color to be used for stroking the path.
- Parameters:
- 
  [in] obj The object. [in] r The red component of the given color. [in] g The green component of the given color. [in] b The blue component of the given color. [in] a The alpha component of the given color. 
- Since (EFL) :
- 1.14
- Since :
- 3.0
| Evas_Vg_Node* evas_vg_shape_stroke_fill_get | ( | const Evas_Vg_Shape * | obj | ) | 
Returns the object that is set for the stroke fill property.
- Parameters:
- 
  [in] obj The object whose stroke fill property is inspected. 
- Returns:
- The object that is set as stroke fill property.
- Since (EFL) :
- 1.24
- Since :
- 3.0
| void evas_vg_shape_stroke_fill_set | ( | Evas_Vg_Shape * | obj, | 
| Evas_Vg_Node * | f | ||
| ) | 
Set a vg object as the stroke fill property.
- Parameters:
- 
  [in] obj The object whose stroke fill property gets modified. [in] f The object content will be used for stroke filling. 
- Since (EFL) :
- 1.24
- Since :
- 3.0
| Evas_Vg_Join evas_vg_shape_stroke_join_get | ( | Evas_Vg_Shape * | obj | ) | 
Gets the join style used for stroking path.
- Parameters:
- 
  [in] obj The object. 
- Returns:
- The join style of the given object.
- Since (EFL) :
- 1.14
- Since :
- 3.0
| void evas_vg_shape_stroke_join_set | ( | Evas_Vg_Shape * | obj, | 
| Evas_Vg_Join | j | ||
| ) | 
Sets the join style to be used for stroking the path.
The join style will be used for joining the two line segment while stroking the path.
- See also:
- Evas_Vg_Join
- Parameters:
- 
  [in] obj The object. [in] j The join style to use, default is EVAS_VG_JOIN_MITER. 
- Since (EFL) :
- 1.14
- Since :
- 3.0
| double evas_vg_shape_stroke_width_get | ( | Evas_Vg_Shape * | obj | ) | 
Gets the stroke width to be used for stroking the path.
- Parameters:
- 
  [in] obj The object. 
- Returns:
- The stroke width of the given object.
- Since (EFL) :
- 1.14
- Since :
- 3.0
| void evas_vg_shape_stroke_width_set | ( | Evas_Vg_Shape * | obj, | 
| double | w | ||
| ) | 
Sets the stroke width to be used for stroking the path.
- Parameters:
- 
  [in] obj The object. [in] w The stroke width to be used. 
- Since (EFL) :
- 1.14
- Since :
- 3.0