blob: 8b562e45d561785d6f2456bc641607f09b91b411 [file] [log] [blame]
<?xml version="1.0" encoding="UTF-8"?>
<!--
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to you 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.
-->
<document id="color-choosers">
<properties>
<title>Color Choosers</title>
<explore>ColorChooser</explore>
</properties>
<body>
<p>
Color choosers, as the name implies, are used to allow the user to select a color. They
present the user with a color spectrum from which the user can select a standard RGB
color.
</p>
<p>
The following example shows a color chooser and will show the user the HTML
representation of the color they have chosen.
</p>
<application class="org.apache.pivot.wtk.ScriptApplication" width="420" height="197">
<libraries>
<library>core</library>
<library>wtk</library>
<library>wtk-terra</library>
<library>tutorials</library>
</libraries>
<startup-properties>
<src>/org/apache/pivot/tutorials/colorchoosers/color_choosers.bxml</src>
</startup-properties>
</application>
<p>The BXML for this example is shown below:</p>
<source type="xml" location="org/apache/pivot/tutorials/colorchoosers/color_choosers.bxml">
<![CDATA[
<Window title="Color Choosers" maximized="true"
WindowStateListener.windowOpened="init()"
xmlns:bxml="http://pivot.apache.org/bxml"
xmlns="org.apache.pivot.wtk">
<bxml:script src="color_choosers.js"/>
<Border>
<BoxPane styles="{padding:4, spacing:12}">
<Border styles="{color:10}">
<ColorChooser bxml:id="colorChooser"
ColorChooserSelectionListener.selectedColorChanged="onColorChange()"/>
</Border>
<Form>
<Form.Section>
<Border Form.label="Selected Color" styles="{padding:1}">
<Border bxml:id="sampleBorder" preferredWidth="100"
preferredHeight="14" styles="{thickness:0}">
<Label/>
</Border>
</Border>
<TextInput bxml:id="hexInput" Form.label="HTML Notation" textSize="6"
ComponentStateListener.focusedChanged="onInputFocusChange()">
<componentKeyListeners>
importClass(org.apache.pivot.wtk.Component);
importClass(org.apache.pivot.wtk.Keyboard);
function keyPressed(component, keyCode, keyLocation) {
if (keyCode == Keyboard.KeyCode.TAB ||
keyCode == Keyboard.KeyCode.ENTER) {
Component.clearFocus();
}
}
</componentKeyListeners>
</TextInput>
</Form.Section>
</Form>
</BoxPane>
</Border>
</Window>
]]>
</source>
<p>The JavaScript for this example, which lives in an external script file, is below:</p>
<source type="js" location="org/apache/pivot/tutorials/colorchoosers/color_choosers.js">
<![CDATA[
/**
* Called when the main app window is opened.
*/
function init() {
colorChooser.selectedColor = "#59a2b0";
}
/**
* Converts a hex string into a Color instance.
*/
function hexToColor(hex) {
if (!hex.startsWith("#")) {
hex = "#" + hex;
}
return java.awt.Color.decode(hex);
}
/**
* Converts a Color instance into a hex string.
*/
function colorToHex(color) {
var result = "";
var primaries = ["red", "green", "blue"];
for (var i = 0, n = primaries.length; i < n; i++) {
var value = color[primaries[i]].toString(16);
if (value.length == 1) {
// Pad the value with a leading zero
value = "0" + value;
}
result += value;
}
return result;
}
/**
* Called when the selected color changes.
*/
function onColorChange() {
var color = colorChooser.selectedColor;
sampleBorder.styles.put("backgroundColor", color);
hexInput.text = colorToHex(color);
}
/**
* Called when the hex input changes its focus state.
*/
function onInputFocusChange() {
if (!hexInput.focused) {
try {
colorChooser.selectedColor = hexToColor(hexInput.text);
} catch (ex) {
var color = colorChooser.selectedColor;
if (color) {
hexInput.text = colorToHex(color);
}
}
}
}
]]>
</source>
<p>
Since this example is written entirely in BXML and script, there is no associated Java
source.
</p>
</body>
</document>