import { IMarkupObject } from "./IMarkupObject";
import { IMarkupColorable } from "./IMarkupColorable";
/**
 * 2D markup Rectangle object interface.
 */
export interface IMarkupRectangle extends IMarkupObject, IMarkupColorable {
    /**
     * Returns the coordinates of the top-left point (position) of the rectangle.
     */
    getPosition(): {
        x: number;
        y: number;
    };
    /**
     * Sets the coordinates of the top-left point (position) of the rectangle.
     */
    setPosition(x: number, y: number): void;
    /**
     * Returns the width of the rectangle.
     */
    getWidth(): number;
    /**
     * Sets the width of the rectangle.
     */
    setWidth(w: number): void;
    /**
     * Returns the height of the rectangle.
     */
    getHeigth(): number;
    /**
     * Sets the height of the rectangle.
     */
    setHeight(h: number): void;
    /**
     * Returns the line width of the rectangle.
     */
    getLineWidth(): number;
    /**
     * Sets the line width of the rectangle.
     */
    setLineWidth(size: number): void;
}
/**
 * Defines the parameters for creating a {@link IMarkupRectangle | markup rectangle}.
 */
export interface IMarkupRectangleParams {
    /**
     * Coordinates of the top-left point (position) of the rectangle.
     */
    position?: {
        x: number;
        y: number;
    };
    /**
     * Width of the rectangle.
     *
     * @default 200
     */
    width?: number;
    /**
     * Height of the rectangle.
     *
     * @default 200
     */
    height?: number;
    /**
     * Line width.
     *
     * @default 4
     */
    lineWidth?: number;
    /**
     * Line color as a string in hexadecimal color syntax `#RGB` color using its primary color components
     * (red, green, blue) written as hexadecimal numbers.
     *
     * @default "#ff0000"
     */
    color?: string;
    /**
     * Internal markup object identifier.
     */
    id?: string;
}
