实现淡入淡出效果的组件,继承自JComponent

简介:

由于仅贴出代码,供有缘人参考。

复制代码
import java.awt.AlphaComposite;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

import javax.swing.JComponent;
import javax.swing.Timer;


public abstract class Page extends JComponent implements ActionListener{
    private static final long serialVersionUID = -1071441396934207094L;
    
    // 帧总量
    private static final int FRAMES_COUNT=10;  
    
    // Timer的时间间隔
    private static final int INTERVAL=50;  
    
    // 定时器
    private Timer timer;
    
    // 每次递增或递减的值
    private int offset=0;
    
    //帧索引  
    private int frameIndex; 
    
    public void paint(Graphics g){  
        if(isTimerRunning()){  
            //根据当前帧显示当前透明度的内容组件  
            float alpha=(float)frameIndex/(float)FRAMES_COUNT;  
            Graphics2D g2d=(Graphics2D)g;  
            g2d.setComposite(AlphaComposite.getInstance(AlphaComposite.SRC_OVER, alpha));  
            //Renderer渲染机制  
            super.paint(g2d);  
        }else{
            super.paint(g);
        }
    }  

    @Override
    public void actionPerformed(ActionEvent e) {
        //前进一帧  
        frameIndex+=offset;  
        if(frameIndex>=FRAMES_COUNT || frameIndex<=0){ 
            //最后一帧,关闭动画  
            closeTimer();  
        }
        else{
            //更新当前一帧  
            repaint();  
        }
    }
    
    // 淡出
    public boolean fadeOut(){
        offset=-1;
        frameIndex=FRAMES_COUNT;
        
        timer=new Timer(INTERVAL,this);
        timer.start();
        
        return true;
    }
    
    // 淡入
    public boolean fadeIn(){
        offset=1;
        frameIndex=0;
        
        timer=new Timer(INTERVAL,this);
        timer.start();
        
        return true;
    }
    
    // 关闭定时器
    protected void closeTimer(){
        if(isTimerRunning()){
            timer.stop();
            timer=null;
        }
        
    }
    
    // 判断定时器是否处于工作状态
    public boolean isTimerRunning(){  
        return timer!=null && timer.isRunning();  
    }  
}
复制代码

 














本文转自张昺华-sky博客园博客,原文链接:http://www.cnblogs.com/xiandedanteng/p/3695268.html,如需转载请自行联系原作者



相关文章
|
前端开发 容器
封装React组件DragLine,鼠标拖拽的边框改变元素宽度
封装React组件DragLine,鼠标拖拽的边框改变元素宽度
185 0
UE4 动画蓝图的嵌套与继承
UE4 动画蓝图的嵌套与继承
172 0
|
前端开发
关于类组件事件绑定的 this 问题
关于类组件事件绑定的 this 问题
82 0
自定义过渡动画
自定义过渡动画
123 0
自定义过渡动画
|
C#
WPF 绑定父类属性
原文:WPF 绑定父类属性 1.绑定父控件的属性. 1 2 3 4 5 6 7 8 9 发现问题,父控件的属性如果是后期加载的,别如说Width或者Height不是固定的数值,那么绑定时没有效果的。
1283 0
html+css实战83-显示模式-继承性
html+css实战83-显示模式-继承性
128 0
html+css实战83-显示模式-继承性
|
Dart 开发者
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(三)
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(三)
186 0
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(三)
Qt Designer设置背景图片、颜色不影响其它组件小技巧,控件层级设置,组件的继承,styleSheet设置样式。
Qt Designer设置背景图片、颜色不影响其它组件小技巧,控件层级设置,组件的继承,styleSheet设置样式。
801 0
Qt Designer设置背景图片、颜色不影响其它组件小技巧,控件层级设置,组件的继承,styleSheet设置样式。
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(二)
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(二)
177 0
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(一)
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(一)
160 0