org.opentcs.util.gui.StringListCellRenderer Maven / Gradle / Ivy
/**
* Copyright (c) The openTCS Authors.
*
* This program is free software and subject to the MIT license. (For details,
* see the licensing information (LICENSE.txt) you should have received with
* this copy of the software.)
*/
package org.opentcs.util.gui;
import static java.util.Objects.requireNonNull;
import java.awt.Component;
import java.util.function.Function;
import javax.swing.DefaultListCellRenderer;
import javax.swing.JLabel;
import javax.swing.JList;
import javax.swing.ListCellRenderer;
/**
* Renders values to JLabels.
*
* @param The type of the values to be rendered.
*/
public class StringListCellRenderer
implements
ListCellRenderer {
/**
* A default renderer for creating the label.
*/
private final DefaultListCellRenderer defaultRenderer = new DefaultListCellRenderer();
/**
* Returns a String representation of E.
*/
private final Function representer;
/**
* Creates an instance.
*
* @param representer a string representation provider for the values of the list.
* Null value as parameter for the representer is possible.
* The result is set as text of the JLabel.
*/
public StringListCellRenderer(Function representer) {
this.representer = requireNonNull(representer, "representer");
}
@Override
public Component getListCellRendererComponent(
JList extends E> list,
E value,
int index,
boolean isSelected,
boolean cellHasFocus
) {
JLabel label = (JLabel) defaultRenderer.getListCellRendererComponent(
list,
value,
index,
isSelected,
cellHasFocus
);
label.setText(representer.apply(value));
return label;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy