简介

最近Java学到了布局管理器,看到GridLayout就很有意思,老师说可以做Excel表格什么的,心中突发奇想,于是就想做一个波纹状按钮效果(事后一想可能是我键盘光效的影响-。-),网上一搜,虽然有这个名词,但是和我想的不太一样。于是开始着手去做。

实现流程

  1. 布局界面
  2. 找到被点击的按钮
  3. 以该按钮为起点进行BFS,搜层次,
  4. 按照层次进行多线程染色

涉及到点

布局管理,按钮数组,多线程,延时,BFS

实现代码

点击查看代码
package test;

import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.util.LinkedList;
import java.util.Queue; class MyLayout extends Frame implements ActionListener{ //按钮数组大小
private int ROWS = 10;
private int COLS = 10; class MyButton extends Button{
public int x,y;//按钮在数组中的下标
public int deep;//按钮的层次
} private MyButton btn[][] = new MyButton[ROWS][COLS];
private int vis[][] = new int[ROWS][COLS];
private Color a = new Color(252,157,154);//原始颜色
private Color b = new Color(254,67,101);//点击颜色
private int dir[][] = new int[][]{{0,1},{1,0},{0,-1},{-1,0}}; public MyLayout() {
//常规设置
this.setTitle("波纹按钮效果示意");
this.setSize(500, 500);
this.setLayout(new GridLayout(ROWS,COLS));//网格状布局
this.setResizable(false);//不可改变大小
//设置窗口在屏幕中央
Dimension screensize = Toolkit.getDefaultToolkit().getScreenSize();
int x = (int) screensize.getWidth() / 2 - this.getWidth() / 2;
int y = (int) screensize.getHeight() / 2 - this.getHeight() / 2;
this.setLocation(x, y);
//设置窗口可见
this.setVisible(true);
//使关闭窗口有效
this.addWindowListener(new WindowAdapter(){
public void windowClosing(WindowEvent e){
MyLayout.this.dispose();
}
}); for(int i=0;i<ROWS;i++) {
for(int j=0;j<COLS;j++) {
btn[i][j] = new MyButton();
btn[i][j].setBackground(a);
btn[i][j].x = i;
btn[i][j].y = j;
btn[i][j].addActionListener(this);//注册监听
this.add(btn[i][j]);
}
}
} @Override
public void actionPerformed(ActionEvent e) {
//获取按钮数组中点击按钮下标
//通过坐标和长宽计算
MyButton bt = (MyButton)e.getSource();
int idx = bt.getY()/bt.getHeight();
int idy = bt.getX()/bt.getWidth();
goButton(idx, idy);
init();
} public void init(){
for(int i=0;i<ROWS;i++){
for(int j=0;j<COLS;j++){
vis[i][j] = 0; //未访问过
}
}
}
public void changeColor(int x,int y,Color preColor,Color nextColor,int time) {
//btn[x][y].setBackground(preColor);
//延时
new Thread() {
public void run() {
btn[x][y].setBackground(preColor);
try {
// System.out.println("延时!+"+time+"end");
Thread.sleep(time);
} catch (InterruptedException e) {
e.printStackTrace();
}
btn[x][y].setBackground(nextColor);
try {
// System.out.println("延时!+"+time+"end");
Thread.sleep(time);
} catch (InterruptedException e) {
e.printStackTrace();
}
btn[x][y].setBackground(preColor);
}
}.start();
} public void goButton(int idx,int idy) {
//BFS
Queue<MyButton> q = new LinkedList<MyButton>();
btn[idx][idy].deep = 0;//起始点第0层
q.offer(btn[idx][idy]);
vis[idx][idy] = 1;
// System.out.println(idx+","+idy+"被调用~");
while(!q.isEmpty()) {
MyButton head = q.poll();
for(int i=0;i<4;i++) {
int tx = head.x + dir[i][0];
int ty = head.y + dir[i][1];
if(judge(tx,ty)) {
btn[tx][ty].deep = head.deep + 1;
changeColor(tx,ty,a, b, btn[tx][ty].deep*50);
q.offer(btn[tx][ty]);
// System.out.println("改变颜色"+tx+','+ty+", deep:"+(head.deep+1));
}
}
}
// System.out.println("size" + q.size());
} public Boolean judge(int idx,int idy) {
if(idx<0||idx>=ROWS||idy<0||idy>=COLS) return false;
if(vis[idx][idy] == 1)return false; //用过了
vis[idx][idy] = 1;
return true;
} }
public class waterButton {
public static void main(String[] args) throws Exception {
/**
* 实现的效果
* 点击一个按钮,然后引发连锁反应变颜色,类似水的波纹
*/
MyLayout ml = new MyLayout();
} }

颜色搭配

搭配1:

原:R:252,G:157,B:154

后:R:254,G:67,B:101

搭配2:

原:R:200,G:200,B:169

后:R:131,G:175,B:155

实现效果

后记

好了,前面装成大佬的样子,现在还原成弱鸡的真实面目,其实我写demo的时候卡住了,无法进展的那种,所以我去请教sc大佬,大佬和我一起讨论,解决问题,感觉很好,最后实际上大佬写出的demo,而大佬的代码再加上一行代码就能实现这个效果。哈哈不过还是很高兴的, 70%成就感啦, 也很开心。

但是在我分享的过程中(弱鸡获得成就感的方式),结果发现,有一个people已经知道了,我很奇怪,追问下去,发现她的朋友psj大佬已经发给她过了,原来sc专业大佬和psj学习大佬,竟然很熟悉!

我不仅感慨

强者还是喜欢和强者一块玩。

想我这种弱鸡,还是需要努力奋斗的。

成就感50%

也很开心啦,是自己一点一点写出来的东西,谁还不心疼呢。

不过,今天还被sc大佬夸奖博客好看

100%成就感

【Java】按钮数组波纹效果的更多相关文章

  1. css3+jQuery实现按钮水波纹效果

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name ...

  2. Java按钮控件数组实现计算器界面

    编写程序,通过按钮数组来管理界面中的所有按钮控件,从而使用最少的代码实现模拟的计算器界面. 思路如下: 创建一个类,通过extends使其继承窗体类JFrame: 创建一个JFrame对象,使用JFr ...

  3. Android自定义组件系列【14】——Android5.0按钮波纹效果实现

    今天任老师发表了一篇关于Android5.0中按钮按下的波纹效果实现<Android L中水波纹点击效果的实现>,出于好奇我下载了源代码看了一下效果,正好手边有一个Nexus手机,我结合实 ...

  4. android自定义控件(4)-自定义水波纹效果

    一.实现单击出现水波纹单圈效果: 照例来说,还是一个自定义控件,观察这个效果,发现应该需要重写onTouchEvent和onDraw方法,通过在onTouchEvent中获取触摸的坐标,然后以这个坐标 ...

  5. Android自己定义控件系列五:自己定义绚丽水波纹效果

    尊重原创!转载请注明出处:http://blog.csdn.net/cyp331203/article/details/41114551 今天我们来利用Android自己定义控件实现一个比較有趣的效果 ...

  6. jquery ripples水波纹效果( 涟漪效果)

    这个效果是我从bootstrap-material-design上面分离下来的,bootstrap-material-design的一些组件样式我不太不喜欢,但是非常喜欢这个水波纹效果,所以就有了这篇 ...

  7. 自定义view实现水波纹效果

    水波纹效果: 1.标准正余弦水波纹: 2.非标准圆形液柱水波纹: 虽说都是水波纹,但两者在实现上差异是比较大的,一个通过正余弦函数模拟水波纹效果,另外一个会运用到图像的混合模式(PorterDuffX ...

  8. Android 自定义view实现水波纹效果

    http://blog.csdn.net/tianjian4592/article/details/44222565 在实际的开发中,很多时候还会遇到相对比较复杂的需求,比如产品妹纸或UI妹纸在哪看了 ...

  9. canvas实现水波纹效果

    本文将会从水波的基本原理开始,详细讲解在canvas中模拟水波扩散,分析并计算水波的能量分布,并通过振幅模拟水波对图像的折射效果,最后实现水波特效. 水波基本原理 首先复习一波高中物理知识. 波是指振 ...

  10. android 按钮特效 波纹 Android button effects ripple

    android 按钮特效 波纹 Android button effects ripple 作者:韩梦飞沙 Author:han_meng_fei_sha 邮箱:313134555@qq.com E- ...

随机推荐

  1. WinHex恢复分区

    情景再现:可能在某一天,打开电脑时发现只剩C盘,剩下的盘找不到了,那么要如何恢复呢? 创建虚拟硬盘方便我们做实验 右键计算机 -> 管理 -> 磁盘管理右键 -> 创建VHD虚拟硬盘 ...

  2. 跳出思维的“盒子”,聊聊 RTE 应用创新大赛的那些作品

    由声网Agora 与环信联合主办的"RTE 2021 编程挑战赛"已圆满落幕.在今年的大赛中,来自行业中不同领域的专家参与了决赛评选,包括 Linux 中国技术社区技术负责人 白宦 ...

  3. SpringBoot接入微信JSSDK,看这篇妥妥的

    先给猴急的客官上干货代码 GitHub 接入微信JSSDK GitHub地址 Gitee 接入微信JSSDK GitHub地址 前言 事情的起因是因为疫情严重,领导要求做一个专题页,能够尽可能帮助所需 ...

  4. 有执行语句:console.log(fn2(2)[3]),补充函数,使执行结果为"hello"

    function fn2(a){ return [1,2,3,"hello"];}console.log(fn2(2)[3])//hello 这个2是混淆视线的,即使没有这个2.函 ...

  5. Android APP开机启动,安卓APP开发自启动,安卓启动后APP自动启动 Android让程序开机自动运行APP 全开源下载

    让APP在安卓系统启动自动运行可以带来以下几个好处:用户方便:当用户打开设备时,自动启动所需的APP可以让用户更方便地使用设备,不必手动打开APP.提高用户黏性:自动启动APP可以让用户更快地开始使用 ...

  6. 在 Linux 内公网、云服务器搭建一套 K8s 集群

    前言 本文讲述如果在 Linux 搭建内/公网 Kubernetes 集群的详细步骤,解决搭建过程中的问题. 准备工作 Linux CentOS 7.x 两台及以上,本文用的 7.6 本文配置默认是在 ...

  7. 最新版本 Stable Diffusion 开源 AI 绘画工具之使用篇

    目录 界面参数 采样器 文生图(txt2img) 图生图(img2img) 模型下载 界面参数 在使用 Stable Diffusion 开源 AI 绘画之前,需要了解一下绘画的界面和一些参数的意义 ...

  8. [Git]解决: error: unable to create file src/main/webapp/xxxxxx/xxxx: Filename too long

    git有可以创建4096长度的文件名,然而在windows最多是260,因为git用了旧版本的windows api,为此踩了个坑. 1 解决方案 $ git config --global core ...

  9. [Linux]CentOS7 安装指定版本软件包

    以安装openssl-libs为例. 查看当前服务器中YUM源可安装的软件包版本 [root@iz2vc84t88x94kno0u49zwz ~]# yum list | grep openssl-l ...

  10. [Linux/JSON]JSON美化工具:json_pp / jq

    json_pp (git-bash内置的用于JSON格式化的管道工具:默认支持) (Linux CentOS7 暂不支持) curl http://localhost:8080/xxxx.json | ...