ht.ui.drawable.ColorDrawable(color, radius)

new ColorDrawable(color, radius)

ColorDrawable 类从 ht.ui.drawable.Drawable 继承,重写了 draw 方法在绘制区域内绘制颜色

Parameters:
Name Type Attributes Description
color string
radius number | Array.<number> <optional>

Extends

Methods

addPropertyChangeListener(listener, scope, ahead) → {void}

增加属性事件变化监听函数

Parameters:
Name Type Attributes Description
listener Object

监听器函数

scope any <optional>

函数域

ahead boolean <optional>

是否将当前监听器插入到监听器列表开头

Returns:
void
Inherited From:

draw(x, y, width, height, data, view, dom) → {void}

绘制内容

Parameters:
Name Type Attributes Description
x number

绘制范围的 x 坐标

y number

绘制范围的 y 坐标

width number

绘制范围的宽度

height number

绘制范围的高度

data ht.Data | ht.ui.View <optional>

绘制相关的 Data 对象,如绘制树组件中节点的 icon 时,可以用此参数判断出当前在绘制哪个节点

view ht.ui.View

当前在绘制的组件

dom HTMLElement <optional>

当前在绘制的 dom 对象,绝大多数组件无需考虑这个参数(因为只有一个绘制 canvas),特殊的是右键菜单,每个子菜单都是一个单独的 canvas,这种情况下才有这个参数

Returns:
void
Inherited From:
Example
// 下面这段代码绘制了一个矩形
function MyDrawable() {
	MyDrawable.superClass.constructor.call(this);
}
ht.Default.def(MyDrawable, ht.ui.drawable.Drawable, {
	draw: function(x, y, width, height, data, view, dom) {
		var g = view.getRootContext(dom);
		g.beginPath();
		g.rect(x, y, width, height);
		g.fillStyle = 'red';
		g.fill();
	}
});

firePropertyChange(property, oldValue, newValue, compareFunc) → {boolean}

派发属性变化事件

Parameters:
Name Type Attributes Description
property string

属性名

oldValue any

属性变化之前的值

newValue any

属性变化之后的值

compareFunc Object <optional>

比较函数,用于比较新值和旧值是否一致,如果一致则不会派发事件

Returns:
boolean -

事件是否派发成功

Inherited From:

fp(property, oldValue, newValue, compareFunc) → {boolean}

派发属性变化事件,firePropertyChange 的缩写

Parameters:
Name Type Attributes Description
property string

属性名

oldValue any

属性变化之前的值

newValue any

属性变化之后的值

compareFunc Object <optional>

比较函数,用于比较新值和旧值是否一致,如果一致则不会派发事件

Returns:
boolean -

事件是否派发成功

Inherited From:

getColor() → {string}

获取要绘制的颜色

Returns:
string -

要绘制的颜色值

getRadius() → {number|Array.<number>}

获取绘制范围的圆角半径

Returns:
number | Array.<number> -

圆角半径;如果是数组,则表示[左上圆角半径, 右上圆角半径, 左下圆角半径, 右下圆角半径]

getSerializableProperties() → {any}

获取可序列化的属性

Returns:
any -

属性 map

Inherited From:

mp(listener, scope, ahead) → {void}

增加属性事件变化监听函数,addPropertyChangeListener 的缩写

Parameters:
Name Type Attributes Description
listener Object

监听器函数

scope any <optional>

函数域

ahead boolean <optional>

是否将当前监听器插入到监听器列表开头

Returns:
void
Inherited From:

removePropertyChangeListener(listener, scope) → {void}

删除属性事件变化监听器

Parameters:
Name Type Attributes Description
listener Object

监听器函数

scope any <optional>

函数域

Returns:
void
Inherited From:

setColor(color) → {void}

设置要绘制的颜色

Parameters:
Name Type Description
color string

要绘制的颜色值,如'red'、'#00ff00' 等

Returns:
void

setRadius(radius) → {void}

设置绘制范围的圆角半径,配合此参数可绘制圆角矩形

Parameters:
Name Type Description
radius number | Array.<number>

圆角半径;如果是数组,则表示[左上圆角半径, 右上圆角半径, 左下圆角半径, 右下圆角半径]

Returns:
void

ump(listener, scope) → {void}

删除属性事件变化监听器,removePropertyChangeListener 的缩写

Parameters:
Name Type Attributes Description
listener Object

监听器函数

scope any <optional>

函数域

Returns:
void
Inherited From: