/*******************************************************************************
* Copyright 2011 See AUTHORS file.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
******************************************************************************/
package com.badlogic.gdx.scenes.scene2d.ui;
import com.badlogic.gdx.graphics.Color;
import com.badlogic.gdx.graphics.g2d.Batch;
import com.badlogic.gdx.graphics.g2d.BitmapFont;
import com.badlogic.gdx.scenes.scene2d.utils.Drawable;
import com.badlogic.gdx.utils.Align;
import com.badlogic.gdx.utils.Scaling;
/** A checkbox is a button that contains an image indicating the checked or unchecked state and a label.
* @author Nathan Sweet */
public class CheckBox extends TextButton {
private Image image;
private Cell imageCell;
private CheckBoxStyle style;
public CheckBox (String text, Skin skin) {
this(text, skin.get(CheckBoxStyle.class));
}
public CheckBox (String text, Skin skin, String styleName) {
this(text, skin.get(styleName, CheckBoxStyle.class));
}
public CheckBox (String text, CheckBoxStyle style) {
super(text, style);
clearChildren();
Label label = getLabel();
imageCell = add(image = new Image(style.checkboxOff, Scaling.none));
add(label);
label.setAlignment(Align.left);
setSize(getPrefWidth(), getPrefHeight());
}
public void setStyle (ButtonStyle style) {
if (!(style instanceof CheckBoxStyle)) throw new IllegalArgumentException("style must be a CheckBoxStyle.");
super.setStyle(style);
this.style = (CheckBoxStyle)style;
}
/** Returns the checkbox's style. Modifying the returned style may not have an effect until {@link #setStyle(ButtonStyle)} is
* called. */
public CheckBoxStyle getStyle () {
return style;
}
public void draw (Batch batch, float parentAlpha) {
Drawable checkbox = null;
if (isDisabled()) {
if (isChecked && style.checkboxOnDisabled != null)
checkbox = style.checkboxOnDisabled;
else
checkbox = style.checkboxOffDisabled;
}
if (checkbox == null) {
if (isChecked && style.checkboxOn != null)
checkbox = style.checkboxOn;
else if (isOver() && style.checkboxOver != null && !isDisabled())
checkbox = style.checkboxOver;
else
checkbox = style.checkboxOff;
}
image.setDrawable(checkbox);
super.draw(batch, parentAlpha);
}
public Image getImage () {
return image;
}
public Cell getImageCell () {
return imageCell;
}
/** The style for a select box, see {@link CheckBox}.
* @author Nathan Sweet */
static public class CheckBoxStyle extends TextButtonStyle {
public Drawable checkboxOn, checkboxOff;
/** Optional. */
public Drawable checkboxOver, checkboxOnDisabled, checkboxOffDisabled;
public CheckBoxStyle () {
}
public CheckBoxStyle (Drawable checkboxOff, Drawable checkboxOn, BitmapFont font, Color fontColor) {
this.checkboxOff = checkboxOff;
this.checkboxOn = checkboxOn;
this.font = font;
this.fontColor = fontColor;
}
public CheckBoxStyle (CheckBoxStyle style) {
super(style);
this.checkboxOff = style.checkboxOff;
this.checkboxOn = style.checkboxOn;
this.checkboxOver = style.checkboxOver;
this.checkboxOffDisabled = style.checkboxOffDisabled;
this.checkboxOnDisabled = style.checkboxOnDisabled;
}
}
}