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

com.alee.extended.label.StyledTextRow Maven / Gradle / Ivy

/*
 * This file is part of WebLookAndFeel library.
 *
 * WebLookAndFeel library is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * WebLookAndFeel library 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 WebLookAndFeel library.  If not, see .
 */

package com.alee.extended.label;

import com.alee.api.annotations.NotNull;
import com.alee.api.annotations.Nullable;
import com.alee.utils.TextUtils;

import java.awt.*;
import java.util.ArrayList;
import java.util.List;

/**
 * Styled text row data.
 *
 * @author Alexandr Zernov
 * @see How to use WebStyledLabel
 */
public class StyledTextRow
{
    /**
     * List of styled text fragments.
     */
    @NotNull
    public final List fragments;

    /**
     * Whether the row is leading (first in text or after hard break) or not.
     */
    public final boolean leading;

    /**
     * Row width.
     */
    public int width;

    /**
     * Row height.
     */
    public int height;

    /**
     * Mnemonic index.
     */
    public int mnemonic;

    /**
     * Constructs row with the specified height.
     *
     * @param height  row height
     * @param leading whether the row is leading (first in text or after hard break) or not
     */
    public StyledTextRow ( final int height, final boolean leading )
    {
        this.fragments = new ArrayList ();
        this.leading = leading;
        this.width = 0;
        this.height = height;
        this.mnemonic = -1;
    }

    /**
     * Appends the row.
     *
     * @param text          text fragment
     * @param style         fragment style
     * @param fm            font metrics
     * @param charOffset    fragment total offset in chars
     * @param mnemonicIndex mnemonic index
     * @return width of appended fragment
     */
    public int append ( @NotNull final String text, @Nullable final StyleRange style, @NotNull final FontMetrics fm,
                        final int charOffset, final int mnemonicIndex )
    {
        int sWidth = 0;
        if ( mnemonicIndex >= 0 && text.length () > mnemonicIndex - charOffset )
        {
            mnemonic = mnemonicIndex - charOffset;
            for ( final TextRange fragment : fragments )
            {
                mnemonic += fragment.text.length ();
            }
        }
        if ( fragments.isEmpty () && !leading )
        {
            // Trimming left first fragment
            final int fw = TextUtils.findFirstWordFromIndex ( text, 0 );
            if ( fw >= 0 )
            {
                final String trimmed = text.substring ( fw );
                fragments.add ( new TextRange ( trimmed, style ) );
                if ( mnemonic > 0 )
                {
                    mnemonic -= fw;
                }
                sWidth += fm.stringWidth ( trimmed );
            }
            else
            {
                if ( mnemonic > 0 )
                {
                    mnemonic -= text.length ();
                }
                fragments.add ( new TextRange ( "", style ) );
            }
        }
        else
        {
            fragments.add ( new TextRange ( text, style ) );
            sWidth += fm.stringWidth ( text );
        }
        width += sWidth;
        return sWidth;
    }

    /**
     * Returns whether the row is empty or not.
     *
     * @return true if  the row is empty, false otherwise
     */
    public boolean isEmpty ()
    {
        return fragments.isEmpty ();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy