48 lines
1.3 KiB
JavaScript
48 lines
1.3 KiB
JavaScript
mexui.util.createControlConstructor('CheckBox', false, function(window, x, y, w, h, text, styles, callback)
|
|
{
|
|
mexui.Component.Control.call(this, window, x, y, w, h, this.linkControlStyles('CheckBox', styles), callback);
|
|
|
|
this.text = text;
|
|
|
|
this.checked = false;
|
|
this.textMarginLeft = 5;
|
|
});
|
|
|
|
// default styles
|
|
mexui.util.linkBaseControlStyles('CheckBox', {
|
|
innerBox:
|
|
{
|
|
backgroundColour: toColour(0, 255, 0, 255)
|
|
}
|
|
});
|
|
|
|
// input
|
|
mexui.Control.CheckBox.prototype.onMouseDown = function(e)
|
|
{
|
|
if(this.isCursorOverControl())
|
|
{
|
|
e.used = true;
|
|
this.checked = !this.checked;
|
|
this.checkToCallCallback();
|
|
}
|
|
};
|
|
|
|
// render
|
|
mexui.Control.CheckBox.prototype.render = function()
|
|
{
|
|
var pos = this.getScreenPosition();
|
|
|
|
mexui.native.drawRectangle(pos, this.size, this.getStyles('main'));
|
|
|
|
if(this.checked)
|
|
mexui.native.drawRectangle(mexui.util.addVec2(pos, new Vec2(1, 1)), new Vec2(this.size.x - 2, this.size.y - 2), this.getStyles('innerBox'));
|
|
|
|
mexui.native.drawText(mexui.util.addVec2(pos, new Vec2(this.size.x + this.textMarginLeft, 2)), this.size, this.text, this.getStyles('main'));
|
|
};
|
|
|
|
// model
|
|
mexui.Control.CheckBox.prototype.getSizeForInput = function()
|
|
{
|
|
var textWidth = mexui.native.getTextWidth(this.text, this.getStyles('main'));
|
|
return new Vec2(this.size.x + this.textMarginLeft + textWidth, this.size.y);
|
|
}; |