Update xml
This commit is contained in:
109
third-party/mexui/Core/Control/RadioButton.js
vendored
109
third-party/mexui/Core/Control/RadioButton.js
vendored
@@ -1,109 +0,0 @@
|
||||
mexui.util.createControlConstructor('RadioButton', false, function(window, x, y, w, h, groupId, text, styles, callback)
|
||||
{
|
||||
mexui.Component.Control.call(this, window, x, y, w, h, this.linkControlStyles('RadioButton', styles), callback);
|
||||
|
||||
this.groupId = groupId;
|
||||
this.text = text;
|
||||
|
||||
this.checked = this.isFirstRadioInGroup();
|
||||
this.textMarginLeft = 5;
|
||||
});
|
||||
|
||||
// default styles
|
||||
mexui.util.linkBaseControlStyles('RadioButton', {
|
||||
innerBox:
|
||||
{
|
||||
backgroundColour: toColour(0, 255, 0, 255)
|
||||
}
|
||||
});
|
||||
|
||||
// input
|
||||
mexui.Control.RadioButton.prototype.onMouseDown = function(e)
|
||||
{
|
||||
if(e.button == 0 && this.isCursorOverControl())
|
||||
{
|
||||
this.setChecked();
|
||||
}
|
||||
};
|
||||
|
||||
mexui.Control.RadioButton.prototype.onKeyDown = function(e, key, mods)
|
||||
{
|
||||
if(this.isFocused())
|
||||
{
|
||||
if(key == SDLK_RETURN || key == SDLK_RETURN2 || key == SDLK_KP_ENTER || key == SDLK_SPACE)
|
||||
{
|
||||
e.used = true;
|
||||
this.setChecked();
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
// render
|
||||
mexui.Control.RadioButton.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(2, 2)), new Vec2(this.size.x - 4, this.size.y - 4), 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'));
|
||||
|
||||
if(this.isFocused())
|
||||
mexui.native.drawRectangleBorder(mexui.util.subtractVec2(pos,new Vec2(2,2)), mexui.util.addVec2(this.size,new Vec2(3,3)), this.getStyles('focused'));
|
||||
};
|
||||
|
||||
// model
|
||||
mexui.Control.RadioButton.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);
|
||||
};
|
||||
|
||||
mexui.Control.RadioButton.prototype.getGroupRadios = function()
|
||||
{
|
||||
var radios = [];
|
||||
var windows = mexui.windows;
|
||||
for(var i in windows)
|
||||
{
|
||||
var window = mexui.windows[i];
|
||||
|
||||
for(var i2 in window.controls)
|
||||
{
|
||||
var control = window.controls[i2];
|
||||
|
||||
if((control instanceof mexui.Control.RadioButton) && this.groupId == control.groupId)
|
||||
{
|
||||
radios.push(control);
|
||||
}
|
||||
}
|
||||
}
|
||||
return radios;
|
||||
};
|
||||
|
||||
mexui.Control.RadioButton.prototype.getCheckedRadio = function()
|
||||
{
|
||||
var radios = this.getGroupRadios();
|
||||
for(var i in radios)
|
||||
{
|
||||
if(radios[i].checked)
|
||||
return radios[i];
|
||||
}
|
||||
return null;
|
||||
};
|
||||
|
||||
mexui.Control.RadioButton.prototype.isFirstRadioInGroup = function()
|
||||
{
|
||||
return this.getGroupRadios().length == 0;
|
||||
};
|
||||
|
||||
mexui.Control.RadioButton.prototype.setChecked = function()
|
||||
{
|
||||
var checkedRadio = this.getCheckedRadio();
|
||||
if(checkedRadio != this.checked)
|
||||
checkedRadio.checked = false;
|
||||
|
||||
this.checked = !this.checked;
|
||||
this.checkToCallCallback();
|
||||
};
|
||||
Reference in New Issue
Block a user