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

com.alee.examples.groups.transition.RandomTransitionExample 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.examples.groups.transition;

import com.alee.examples.WebLookAndFeelDemo;
import com.alee.examples.content.DefaultExample;
import com.alee.extended.image.WebImage;
import com.alee.extended.panel.CenterPanel;
import com.alee.extended.panel.GroupPanel;
import com.alee.extended.transition.ComponentTransition;
import com.alee.extended.transition.TransitionListener;
import com.alee.extended.transition.effects.Direction;
import com.alee.extended.transition.effects.blocks.BlocksTransitionEffect;
import com.alee.extended.transition.effects.curtain.CurtainTransitionEffect;
import com.alee.extended.transition.effects.curtain.CurtainType;
import com.alee.extended.transition.effects.fade.FadeTransitionEffect;
import com.alee.extended.transition.effects.slide.SlideTransitionEffect;
import com.alee.extended.transition.effects.zoom.ZoomTransitionEffect;
import com.alee.laf.button.WebButton;
import com.alee.utils.SwingUtils;

import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

/**
 * User: mgarin Date: 20.11.12 Time: 20:11
 */

public class RandomTransitionExample extends DefaultExample
{
    @Override
    public String getTitle ()
    {
        return "Random transition";
    }

    @Override
    public String getDescription ()
    {
        return "Random transition effect";
    }

    @Override
    public Component getPreview ( WebLookAndFeelDemo owner )
    {
        // Transition panel
        final ComponentTransition componentTransition = new ComponentTransition ();

        // Transition effects (one of them is choosen randomly when transition occurs)
        componentTransition.addTransitionEffect ( createFadeTransitionEffect () );
        componentTransition.addTransitionEffect ( createFadeCurtainEffect () );
        componentTransition.addTransitionEffect ( createFillCurtainEffect () );
        componentTransition.addTransitionEffect ( createHorizontalSlideCurtainEffect () );
        componentTransition.addTransitionEffect ( createVerticalSlideCurtainEffect () );
        componentTransition.addTransitionEffect ( createFadeBlockTransitionEffect () );
        componentTransition.addTransitionEffect ( createBlockTransitionEffect () );
        componentTransition.addTransitionEffect ( createFadeSlideTransitionEffect () );
        componentTransition.addTransitionEffect ( createSlideTransitionEffect () );
        componentTransition.addTransitionEffect ( createZoomTransitionEffect () );

        // Effects
        final WebImage image1 = new WebImage ( loadIcon ( "pictures/1.jpg" ) );
        final WebImage image2 = new WebImage ( loadIcon ( "pictures/2.jpg" ) );
        final WebImage image3 = new WebImage ( loadIcon ( "pictures/3.jpg" ) );

        // Initial transition panel state
        componentTransition.setContent ( image1 );
        componentTransition.setPreferredSize ( SwingUtils.max ( image1, image2 ) );

        // Images switch button
        final WebButton switchView = new WebButton ( loadIcon ( "switch.png" ) );
        switchView.setDrawFocus ( false );
        switchView.addActionListener ( new ActionListener ()
        {
            @Override
            public void actionPerformed ( ActionEvent e )
            {
                if ( componentTransition.getContent () == image1 )
                {
                    componentTransition.performTransition ( image2 );
                }
                else if ( componentTransition.getContent () == image2 )
                {
                    componentTransition.performTransition ( image3 );
                }
                else
                {
                    componentTransition.performTransition ( image1 );
                }
            }
        } );
        componentTransition.addTransitionListener ( new TransitionListener ()
        {
            @Override
            public void transitionStarted ()
            {
                switchView.setEnabled ( false );
            }

            @Override
            public void transitionFinished ()
            {
                switchView.setEnabled ( true );
            }
        } );

        return new GroupPanel ( 10, componentTransition, new CenterPanel ( switchView ) );
    }

    private FadeTransitionEffect createFadeTransitionEffect ()
    {
        FadeTransitionEffect effect = new FadeTransitionEffect ();
        effect.setMinimumSpeed ( 0.03f );
        effect.setSpeed ( 0.1f );
        return effect;
    }

    private ZoomTransitionEffect createZoomTransitionEffect ()
    {
        ZoomTransitionEffect effect = new ZoomTransitionEffect ();
        effect.setMinimumSpeed ( 0.03f );
        effect.setSpeed ( 0.1f );
        return effect;
    }

    private CurtainTransitionEffect createFadeCurtainEffect ()
    {
        CurtainTransitionEffect effect = new CurtainTransitionEffect ();
        effect.setSpeed ( 2 );
        effect.setSize ( 20 );
        effect.setType ( CurtainType.fade );
        return effect;
    }

    private CurtainTransitionEffect createFillCurtainEffect ()
    {
        CurtainTransitionEffect effect = new CurtainTransitionEffect ();
        effect.setSpeed ( 2 );
        effect.setSize ( 40 );
        effect.setType ( CurtainType.fill );
        return effect;
    }

    private CurtainTransitionEffect createHorizontalSlideCurtainEffect ()
    {
        CurtainTransitionEffect effect = new CurtainTransitionEffect ();
        effect.setSpeed ( 20 );
        effect.setSize ( 20 );
        effect.setType ( CurtainType.slide );
        effect.setDirection ( Direction.horizontal );
        return effect;
    }

    private CurtainTransitionEffect createVerticalSlideCurtainEffect ()
    {
        CurtainTransitionEffect effect = new CurtainTransitionEffect ();
        effect.setSpeed ( 30 );
        effect.setSize ( 20 );
        effect.setType ( CurtainType.slide );
        effect.setDirection ( Direction.vertical );
        return effect;
    }

    private BlocksTransitionEffect createFadeBlockTransitionEffect ()
    {
        BlocksTransitionEffect effect = new BlocksTransitionEffect ();
        effect.setSize ( 40 );
        effect.setSpeed ( 4 );
        return effect;
    }

    private BlocksTransitionEffect createBlockTransitionEffect ()
    {
        BlocksTransitionEffect effect = new BlocksTransitionEffect ();
        effect.setFade ( false );
        effect.setSize ( 40 );
        effect.setSpeed ( 4 );
        return effect;
    }

    private SlideTransitionEffect createFadeSlideTransitionEffect ()
    {
        return new SlideTransitionEffect ();
    }

    private SlideTransitionEffect createSlideTransitionEffect ()
    {
        SlideTransitionEffect effect = new SlideTransitionEffect ();
        effect.setFade ( false );
        return effect;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy