|  |  |  | Eye of GNOME Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
EogUta * uta_ensure_size (EogUta *uta, int x1, int y1, int x2, int y2); EogUta * uta_add_rect (EogUta *uta, int x1, int y1, int x2, int y2); void uta_remove_rect (EogUta *uta, int x1, int y1, int x2, int y2); void uta_find_first_glom_rect (EogUta *uta, EogIRect *rect, int max_width, int max_height); void uta_copy_area (EogUta *uta, int src_x, int src_y, int dest_x, int dest_y, int width, int height);
EogUta * uta_ensure_size (EogUta *uta, int x1, int y1, int x2, int y2);
Ensures that the size of a microtile array is big enough to fit the specified
microtile coordinates.  If it is not big enough, the specified uta will be
freed and a new one will be returned.  Otherwise, the original uta will be
returned.  If a new microtile array needs to be created, this function will
copy the uta's contents to the new array.
Note that the specified coordinates must have already been scaled down by the ART_UTILE_SHIFT factor.
| 
 | A microtile array. | 
| 
 | Left microtile coordinate that must fit in new array. | 
| 
 | Top microtile coordinate that must fit in new array. | 
| 
 | Right microtile coordinate that must fit in new array. | 
| 
 | Bottom microtile coordinate that must fit in new array. | 
| Returns : | The same value as utaif the original microtile array was
big enough to fit the specified microtile coordinates, or a new array if
it needed to be grown.  In the second case, the originalutawill be
freed automatically. | 
EogUta * uta_add_rect (EogUta *uta, int x1, int y1, int x2, int y2);
Adds the specified rectangle to a microtile array. The array is grown to fit the rectangle if necessary.
| 
 | A microtile array, or NULL if a new array should be created. | 
| 
 | Left coordinate of rectangle. | 
| 
 | Top coordinate of rectangle. | 
| 
 | Right coordinate of rectangle. | 
| 
 | Bottom coordinate of rectangle. | 
| Returns : | The original uta, or a new microtile array if the original one
needed to be grown to fit the specified rectangle.  In the second case, the
originalutawill be freed automatically. | 
void uta_remove_rect (EogUta *uta, int x1, int y1, int x2, int y2);
Removes a rectangular region from the specified microtile array. Due to the way microtile arrays represent regions, the tiles at the edge of the rectangle may not be clipped exactly.
| 
 | A microtile array. | 
| 
 | Left coordinate of rectangle. | 
| 
 | Top coordinate of rectangle. | 
| 
 | Right coordinate of rectangle. | 
| 
 | Bottom coordinate of rectangle. | 
void uta_find_first_glom_rect (EogUta *uta, EogIRect *rect, int max_width, int max_height);
| 
 | |
| 
 | |
| 
 | |
| 
 | 
void uta_copy_area (EogUta *uta, int src_x, int src_y, int dest_x, int dest_y, int width, int height);
Copies a rectangular region within a microtile array. The array will not be expanded if the destination area does not fit within it; rather only the area that fits will be copied. The source rectangle must be completely contained within the microtile array.
| 
 | A microtile array. | 
| 
 | Left coordinate of source rectangle. | 
| 
 | Top coordinate of source rectangle. | 
| 
 | Left coordinate of destination. | 
| 
 | Top coordinate of destination. | 
| 
 | Width of region to copy. | 
| 
 | Height of region to copy. |