Java Swing Empty Border correctBorder(final JComponent comp)

Here you can find the source of correctBorder(final JComponent comp)

Description

Called for each tab panel component that is derived from a JComponent.

License

Open Source License

Parameter

Parameter Description
Component of a tab panel. Can be null.

Declaration

private static void correctBorder(final JComponent comp) 

Method Source Code

//package com.java2s;
/*/*w  w w  .j  a va 2s  .c o  m*/
 * ------------------------------------------------------------------
 * This source code, its documentation and all appendant files
 * are protected by copyright law. All rights reserved.
 *
 * Copyright (C) 2012
 * Novartis Institutes for BioMedical Research
 *
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License, Version 3, as
 *  published by the Free Software Foundation.
 *
 *  This program is distributed in the hope that it will be useful, but
 *  WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, see <http://www.gnu.org/licenses>.
 *
 *  Additional permission under GNU GPL version 3 section 7:
 *
 *  KNIME interoperates with ECLIPSE solely via ECLIPSE's plug-in APIs.
 *  Hence, KNIME and ECLIPSE are both independent programs and are not
 *  derived from each other. Should, however, the interpretation of the
 *  GNU GPL Version 3 ("License") under any applicable laws result in
 *  KNIME and ECLIPSE being a combined program, KNIME GMBH herewith grants
 *  you the additional permission to use and propagate KNIME together with
 *  ECLIPSE with only the license terms in place for ECLIPSE applying to
 *  ECLIPSE and the GNU GPL Version 3 applying for KNIME, provided the
 *  license terms of ECLIPSE themselves allow for the respective use and
 *  propagation of ECLIPSE together with KNIME.
 *
 *  Additional permission relating to nodes for KNIME that extend the Node
 *  Extension (and in particular that are based on subclasses of NodeModel,
 *  NodeDialog, and NodeView) and that only interoperate with KNIME through
 *  standard APIs ("Nodes"):
 *  Nodes are deemed to be separate and independent programs and to not be
 *  covered works.  Notwithstanding anything to the contrary in the
 *  License, the License does not apply to Nodes, you are not required to
 *  license Nodes under the License, and you are granted a license to
 *  prepare and propagate Nodes, in each case even if such Nodes are
 *  propagated with or for interoperation with KNIME.  The owner of a Node
 *  may freely choose the license terms applicable to such Node, including
 *  when such Node is propagated with or for interoperation with KNIME.
 * ---------------------------------------------------------------------
 */

import javax.swing.BorderFactory;

import javax.swing.JComponent;

import javax.swing.border.Border;
import javax.swing.border.CompoundBorder;
import javax.swing.border.EmptyBorder;

public class Main {
    /**
     * Called for each tab panel component that is derived from a JComponent.
     * This method is used to set borders around the inner components
     * of a tab panel.
     * 
     * @param Component of a tab panel. Can be null.
     */
    private static void correctBorder(final JComponent comp) {
        if (comp != null) {
            Border border = comp.getBorder();

            if (border == null) {
                border = BorderFactory.createEmptyBorder(7, 7, 7, 7);
            } else if (border instanceof EmptyBorder == false && (border instanceof CompoundBorder == false
                    || ((CompoundBorder) border).getOutsideBorder() instanceof EmptyBorder == false)) {
                border = BorderFactory.createCompoundBorder(BorderFactory.createEmptyBorder(7, 7, 7, 7), border);
            }

            comp.setBorder(border);
        }
    }
}

Related

  1. blankBorder(int top, int left, int bottom, int right)
  2. borderlessScrollPane(final Component component)
  3. buildInfoPanelEmptyBorderScroll(final JComponent content)
  4. buildPanelEmptyBorder(final JComponent content, final int top, final int left, final int bottom, final int right)
  5. contentPaneBorder(JComponent component)
  6. createEmptyBorder(int size)
  7. createInnerBorder(int size)
  8. getAlignBorder()
  9. getBigBorder()