blob: f4f860d88fc2c0f05527e13c3cd3fe5ab80d1b78 [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="repeatable-list-buttons">
<properties>
<title>Repeatable List Buttons</title>
</properties>
<body>
<p>
The following example demonstrates Pivot's support for "repeatable" list buttons.
A repeatable list button allows a user to easily repeat the action associated with
the currently selected item. They are often used to define "rubber stamp" behaviors
that are applied to one or more selected items.
</p>
<p>
For example, the list button in the example allows the user to change the text color
of the selected checkboxes. Clicking the drop-down arrow presents a list of color
options, and clicking the currently selected color re-applies the color selection
to the currently selected checkboxes:
</p>
<application class="org.apache.pivot.wtk.ScriptApplication"
width="320" height="220">
<libraries>
<library>core</library>
<library>wtk</library>
<library>wtk-terra</library>
<library>tutorials</library>
</libraries>
<startup-properties>
<src>/org/apache/pivot/tutorials/lists/repeatable_list_buttons.bxml</src>
</startup-properties>
</application>
<p>
The BXML source for the example is as follows:
</p>
<source type="xml" location="org/apache/pivot/tutorials/lists/repeatable_list_buttons.bxml">
<![CDATA[
<lists:RepeatableListButtons title="Repeatable List Buttons" maximized="true"
xmlns:bxml="http://pivot.apache.org/bxml"
xmlns:content="org.apache.pivot.wtk.content"
xmlns:lists="org.apache.pivot.tutorials.lists"
xmlns="org.apache.pivot.wtk">
<Border styles="{padding:8}">
<TablePane styles="{horizontalSpacing:4}">
<columns>
<TablePane.Column width="-1"/>
<TablePane.Column width="1*"/>
</columns>
<TablePane.Row height="1*">
<FlowPane>
<Label text="Color:"/>
<ListButton bxml:id="colorListButton" Form.label="Color"
repeatable="true" action="applyColor" listSize="8"
selectedIndex="0">
<dataRenderer>
<content:ListButtonColorItemRenderer/>
</dataRenderer>
<itemRenderer>
<content:ListViewColorItemRenderer/>
</itemRenderer>
<content:ColorItem color="#000000" name="Black"/>
<content:ColorItem color="#0000AA" name="Blue"/>
<content:ColorItem color="#00AA00" name="Green"/>
<content:ColorItem color="#00AAAA" name="Cyan"/>
<content:ColorItem color="#AA0000" name="Red"/>
<content:ColorItem color="#AA00AA" name="Magenta"/>
<content:ColorItem color="#AA5500" name="Brown"/>
<content:ColorItem color="#AAAAAA" name="Light Gray"/>
<content:ColorItem color="#555555" name="Dark Gray"/>
<content:ColorItem color="#5555FF" name="Bright Blue"/>
<content:ColorItem color="#55FF55" name="Bright Green"/>
<content:ColorItem color="#55FFFF" name="Bright Cyan"/>
<content:ColorItem color="#FF5555" name="Bright Red"/>
<content:ColorItem color="#FF55FF" name="Bright Magenta"/>
<content:ColorItem color="#FFFF55" name="Bright Yellow"/>
<content:ColorItem color="#FFFFFF" name="White"/>
</ListButton>
</FlowPane>
<Border>
<ScrollPane>
<BoxPane bxml:id="checkboxBoxPane" orientation="vertical"
styles="{padding:4, spacing:4}"/>
</ScrollPane>
</Border>
</TablePane.Row>
</TablePane>
</Border>
</lists:RepeatableListButtons>
]]>
</source>
<p>
The Java source for the example is shown below. The logic for applying the color
selection is encapsulated in the anonymous "applyColor" action defined by the
<tt>applyColorAction</tt> member. The rest of the code simply manages the selection
state of the checkboxes:
</p>
<source type="java" location="org/apache/pivot/tutorials/lists/RepeatableListButtons.java">
<![CDATA[
package org.apache.pivot.tutorials.lists;
import java.awt.Color;
import java.net.URL;
import org.apache.pivot.beans.Bindable;
import org.apache.pivot.collections.ArrayList;
import org.apache.pivot.collections.Map;
import org.apache.pivot.util.Resources;
import org.apache.pivot.wtk.Action;
import org.apache.pivot.wtk.BoxPane;
import org.apache.pivot.wtk.Button;
import org.apache.pivot.wtk.ButtonStateListener;
import org.apache.pivot.wtk.Checkbox;
import org.apache.pivot.wtk.Component;
import org.apache.pivot.wtk.ListButton;
import org.apache.pivot.wtk.Style;
import org.apache.pivot.wtk.Window;
import org.apache.pivot.wtk.Button.State;
import org.apache.pivot.wtk.content.ColorItem;
public class RepeatableListButtons extends Window implements Bindable {
private ListButton colorListButton = null;
private BoxPane checkboxBoxPane = null;
private int selectedCount = 0;
private Action applyColorAction = new Action() {
@Override
public void perform(Component source) {
ColorItem colorItem = (ColorItem)colorListButton.getButtonData();
Color color = colorItem.getColor();
for (Component component : checkboxBoxPane) {
Checkbox checkbox = (Checkbox)component;
if (checkbox.isSelected()) {
checkbox.getStyles().put(Style.color, color);
checkbox.setSelected(false);
}
}
}
};
public RepeatableListButtons() {
Action.getNamedActions().put("applyColor", applyColorAction);
applyColorAction.setEnabled(false);
}
@Override
public void initialize(Map<String, Object> namespace, URL location, Resources resources) {
colorListButton = (ListButton)namespace.get("colorListButton");
checkboxBoxPane = (BoxPane)namespace.get("checkboxBoxPane");
ButtonStateListener buttonStateListener = new ButtonStateListener() {
@Override
public void stateChanged(Button button, State previousState) {
if (button.isSelected()) {
selectedCount++;
} else {
selectedCount--;
}
applyColorAction.setEnabled(selectedCount > 0);
}
};
ArrayList<String> numbers = new ArrayList<String>("One", "Two", "Three", "Four", "Five",
"Six", "Seven", "Eight", "Nine", "Ten");
for (String number : numbers) {
Checkbox checkbox = new Checkbox(number);
checkbox.getButtonStateListeners().add(buttonStateListener);
checkboxBoxPane.add(checkbox);
}
}
}
]]>
</source>
</body>
</document>