All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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 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