Java实现淡入淡出窗口

转载自:

一。代码

package org.bruce.vertices.extra.experiments;

/* * 
 * 淡入淡出窗口,淡出时,如果鼠标移进去了,则中止渐变。
 */
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import javax.swing.*;

public class GCFrame {
	protected static Timer timer;
	static JFrame jf;
	static float value = 1.0f;
	boolean isClicked = false;

	public GCFrame() {
		jf = new JFrame();
		JPanel jp = new JPanel();
		JButton jb = new JButton("淡出");
		jp.add(jb);
		jf.add(jp);
		jf.setSize(320, 240);
		jf.setVisible(true);
		// 添加按钮的监听事件
		timer = new Timer(100, new Tim1());
		jb.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				timer.start();
				isClicked = true;
				// 当鼠标移入窗口时,中止线程,当点击了“淡出”按钮后添加事件监听代码
				if (isClicked == true) {
					jf.addMouseListener(new MouseAdapter() {
						public void mouseEntered(MouseEvent e) {
							timer.stop();
							value = 1.0f;
							SwingUtilities.invokeLater(new Runnable() {
								public void run() {
									com.sun.awt.AWTUtilities.setWindowOpacity(jf, value);
								}
							});
						}

						public void mouseExited(MouseEvent e) {
							timer.start();
						}
					});
				}
			}
		});
	}

	static class Tim0 implements ActionListener {// 控制窗口打开时透明度的渐变
		public void actionPerformed(ActionEvent e) {
		}
	}

	static class Tim1 implements ActionListener {// 控制窗口关闭时透明度的渐变
		public void actionPerformed(ActionEvent e) {
			value -= 0.02f;
			if (value >= 0.02f) {
				SwingUtilities.invokeLater(new Runnable() {
					public void run() {
						com.sun.awt.AWTUtilities.setWindowOpacity(jf, value);
					}
				});
			} else {
				System.exit(0);
			}
		}
	}

	public static void main(String[] args) {
		new GCFrame();
	}
}


二。效果图


转载于:https://www.cnblogs.com/yang3wei/archive/2012/06/23/2739692.html

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现图片的淡入淡出效果,可以通过css的opacity属性来控制。具体实现步骤如下: 1. 在wxml文件中,创建一个image标签,并设置两张图片路径,如下: ``` <image class="fade" src="{{imageUrl1}}"></image> <image class="fade" src="{{imageUrl2}}"></image> ``` 2. 在wxss文件中添加以下样式: ``` .fade { position: absolute; left: 0; top: 0; width: 100%; height: 100%; opacity: 0; transition: opacity 1s ease-in-out; } ``` 其中,opacity属性设置为0,表示图片开始时隐藏,transition属性设置为1s,表示过渡时间为1秒,ease-in-out表示过渡效果为渐进渐出。 3. 在js文件的onLoad函数中,设置定时器,用来控制图片的淡入淡出效果: ``` onLoad: function(options) { setInterval(() => { this.setData({ hasShowFirstImage: !this.data.hasShowFirstImage }); }, 2000); } ``` 其中,定时器每隔2秒执行一次,将hasShowFirstImage属性取反,用来控制两张图片的显示隐藏。 4. 在js文件的setData函数中,根据hasShowFirstImage的值,改变两张图片的透明度,实现淡入淡出: ``` setData({ hasShowFirstImage: !this.data.hasShowFirstImage, imageUrl1: this.data.hasShowFirstImage ? img2 : img1, imageUrl2: this.data.hasShowFirstImage ? img1 : img2, }); ``` 这里使用了三目运算符来判断当前应该显示哪一张图片,然后将另一张图片的opacity属性设置为0,当前显示的图片的opacity属性设置为1,实现淡入淡出效果。 最终效果为图片每隔两秒自动淡入淡出一次。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值