java 代码实现《黑客帝国》酷炫数字雨效果

本贴最后更新于 3269 天前,其中的信息可能已经事过境迁

直接上效果图:

1472700330637

目前的样子还可以美化,期待其他童鞋效果图 0.0
下边是代码

package cn.com.entity; import java.awt.BorderLayout; import java.awt.Color; import java.awt.Cursor; import java.awt.Dimension; import java.awt.Font; import java.awt.Graphics; import java.awt.Graphics2D; import java.awt.Image; import java.awt.Point; import java.awt.Toolkit; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.KeyAdapter; import java.awt.event.KeyEvent; import java.awt.image.MemoryImageSource; import java.util.Random; import javax.swing.JDialog; import javax.swing.JPanel; import javax.swing.Timer; public class Rain extends JDialog implements ActionListener { private static final long serialVersionUID = 1549334578038217282L; private Random random = new Random(); private Dimension screenSize; private JPanel graphicsPanel; // 行高,列宽 private final static int gap = 20; // 存放雨点顶部的位置信息(marginTop) private int[] posArr; // 行数 private int lines; // 列数 private int columns; public Rain() { initComponents(); } private void initComponents() { setLayout(new BorderLayout()); graphicsPanel = new GraphicsPanel(); add(graphicsPanel, BorderLayout.CENTER); // 设置光标不可见 Toolkit defaultToolkit = Toolkit.getDefaultToolkit(); Image image = defaultToolkit.createImage(new MemoryImageSource(0, 0, null, 0, 0)); Cursor invisibleCursor = defaultToolkit.createCustomCursor(image, new Point(0, 0), "cursor"); setCursor(invisibleCursor); // ESC键退出 KeyPressListener keyPressListener = new KeyPressListener(); this.addKeyListener(keyPressListener); // this.setAlwaysOnTop(true); // 去标题栏 this.setUndecorated(true); // 全屏 this.getGraphicsConfiguration().getDevice().setFullScreenWindow(this); this.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE); setVisible(true); screenSize = Toolkit.getDefaultToolkit().getScreenSize(); lines = screenSize.height / gap; columns = screenSize.width / gap; posArr = new int[columns + 1]; random = new Random(); for (int i = 0; i < posArr.length; i++) { posArr[i] = random.nextInt(lines); } // 每秒10帧 new Timer(100, this).start(); } /** * @return 随机字符 */ private char getChr() { return (char) (random.nextInt(94) + 33); } @Override public void actionPerformed(ActionEvent e) { graphicsPanel.repaint(); } private class GraphicsPanel extends JPanel { private static final long serialVersionUID = 3043939524168375053L; @Override public void paint(Graphics g) { Graphics2D g2d = (Graphics2D) g; g2d.setFont(getFont().deriveFont(Font.BOLD)); g2d.setColor(Color.BLACK); g2d.fillRect(0, 0, screenSize.width, screenSize.height); // 当前列 int currentColumn = 0; for (int x = 0; x < screenSize.width; x += gap) { int endPos = posArr[currentColumn]; g2d.setColor(Color.CYAN); g2d.drawString(String.valueOf(getChr()), x, endPos * gap); int cg = 0; for (int j = endPos - 15; j < endPos; j++) { // 颜色渐变 cg += 20; if (cg > 255) { cg = 255; } g2d.setColor(new Color(0, cg, 0)); g2d.drawString(String.valueOf(getChr()), x, j * gap); } // 每放完一帧,当前列上雨点的位置随机下移1~5行 posArr[currentColumn] += random.nextInt(5); // 当雨点位置超过屏幕高度时,重新产生一个随机位置 if (posArr[currentColumn] * gap > getHeight()) { posArr[currentColumn] = random.nextInt(lines); } currentColumn++; } } } private class KeyPressListener extends KeyAdapter { @Override public void keyPressed(KeyEvent e) { if (e.getKeyCode() == KeyEvent.VK_ESCAPE) { System.exit(0); } } } public static void main(String[] args) { new Rain(); } }

这是 html 版的

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <style type="text/css"> canvas { display: block; } </style> </head> <body> <canvas id="canvas"></canvas> <script> function $(id) { return document.getElementById(id); } //画布 的大小设置 var mywindow = window.screen; var canvas = $("canvas"); canvas.width = mywindow.width; canvas.height = mywindow.height; //要输出的信息 var str = "0123456789"; str = str.split(""); var fontSize = 16;//输出字体的大小 //每列显示多少个信息 var cols = canvas.width / fontSize; //数组,统计下落的位置 var drops = []; for (var i = 0; i < cols; i++) { drops[i] = 1; } var ctx = canvas.getContext("2d"); function draw() { /** *这的黑客帝国: * 获取页面的 大小 包括宽度和高度 * 用cols获取能够宽度加载列数 * drops加载每一列的位置 * drops[2]=10 2为第二排的 top为10 */ ctx.fillStyle = "rgba(0,0,0,0.05)"; ctx.fillRect(0, 0, canvas.width, canvas.height); ctx.fillStyle = "green"; ctx.font = fontSize + "px arial"; for (var i = 0; i < cols; i++) { var text = str[Math.floor(Math.random() * (str.length))]; // console.info("x-"+i*fontSize); // console.info("y-"+drops[i]*fontSize); ctx.fillText(text, i * fontSize, drops[i] * fontSize); if (drops[i] * fontSize > canvas.height || Math.random() > 0.95) drops[i] = 0;//把位置恢复到最上面 //控制下落的位置 drops[i]++; } } setInterval(draw, 33); </script> </body> </html>
  • 分享

    有什么新发现就分享给大家吧!

    248 引用 • 1795 回帖 • 1 关注
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3203 引用 • 8217 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • relyn

    改成 JS 版吧,哈哈

  • 88250

    这个是屏保版 [1471919913151]

  • Stone
    作者

    @88250 我看过这个,因为不是全屏的不是全屏的

  • 88250

    贴代码的时候用 Markdown GFM 语法吧

  • Stone
    作者

    @88250 不知道怎么搞,刚才发 html 竟然没出来

    1 回复
  • 88250

    用 ``` 把代码块包起来就行

  • ZephyrJung 1 2 赞同

    酷,最喜欢这种代码可直接运行的东西 👍

  • Stone
    作者

    以前从来没写过博客,格式的东西一窍不通,刚才看了一下你说的 Markdown GFM 语法 需要加一些标签才能实现 0.0

    1 回复
  • 88250

    我帮你更新了一下,你点编辑看下内容就知道怎么高亮代码了,注意 ``` 。

  • Stone
    作者

    @88250 感谢 D 大 嘿嘿

    1 回复
  • 88250 1

    请点感谢,哈哈

  • Stone
    作者

    @88250 卧槽(二声:表示疑问)还有这功能!!

    1 回复
  • 88250

    有很多功能的啦,慢慢探索一下 😍

  • junze

    用 jS 就 OK

  • wstv 1

    很强势的代码

  • newsky001 1

    这个试了一下,很强势

  • ZephyrJung 1 赞同

    楼主你好,我将这段代码放到了 github 上,请知悉 🙏
    如觉不妥,我将立刻删除
    https://github.com/ZephyrJung/html5

请输入回帖内容 ...

推荐标签 标签

  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 651 关注
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 13 关注
  • 微服务

    微服务架构是一种架构模式,它提倡将单一应用划分成一组小的服务。服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在独立的进程中。服务于服务之间才用轻量级的通信机制互相沟通。每个服务都围绕着具体业务构建,能够被独立的部署。

    96 引用 • 155 回帖
  • OpenCV
    15 引用 • 36 回帖
  • 七牛云

    七牛云是国内领先的企业级公有云服务商,致力于打造以数据为核心的场景化 PaaS 服务。围绕富媒体场景,七牛先后推出了对象存储,融合 CDN 加速,数据通用处理,内容反垃圾服务,以及直播云服务等。

    29 引用 • 230 回帖 • 123 关注
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 118 关注
  • Redis

    Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

    284 引用 • 248 回帖 • 3 关注
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    181 引用 • 400 回帖
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖 • 1 关注
  • RemNote
    2 引用 • 16 回帖 • 25 关注
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖 • 1 关注
  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖 • 2 关注
  • 浅吟主题

    Jeffrey Chen 制作的思源笔记主题,项目仓库:https://github.com/TCOTC/Whisper

    2 引用 • 32 回帖
  • 游戏

    沉迷游戏伤身,强撸灰飞烟灭。

    188 引用 • 832 回帖
  • Typecho

    Typecho 是一款博客程序,它在 GPLv2 许可证下发行,基于 PHP 构建,可以运行在各种平台上,支持多种数据库(MySQL、PostgreSQL、SQLite)。

    12 引用 • 67 回帖 • 447 关注
  • Outlook
    1 引用 • 5 回帖
  • OnlyOffice
    4 引用 • 18 关注
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    240 引用 • 224 回帖
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    36 引用 • 35 回帖 • 1 关注
  • AWS
    11 引用 • 28 回帖 • 3 关注
  • React

    React 是 Facebook 开源的一个用于构建 UI 的 JavaScript 库。

    192 引用 • 291 回帖 • 368 关注
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    167 引用 • 597 回帖 • 1 关注
  • OkHttp

    OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。

    16 引用 • 6 回帖 • 92 关注
  • 强迫症

    强迫症(OCD)属于焦虑障碍的一种类型,是一组以强迫思维和强迫行为为主要临床表现的神经精神疾病,其特点为有意识的强迫和反强迫并存,一些毫无意义、甚至违背自己意愿的想法或冲动反反复复侵入患者的日常生活。

    15 引用 • 161 回帖 • 2 关注
  • 尊园地产

    昆明尊园房地产经纪有限公司,即:Kunming Zunyuan Property Agency Company Limited(简称“尊园地产”)于 2007 年 6 月开始筹备,2007 年 8 月 18 日正式成立,注册资本 200 万元,公司性质为股份经纪有限公司,主营业务为:代租、代售、代办产权过户、办理银行按揭、担保、抵押、评估等。

    1 引用 • 22 回帖 • 808 关注
  • 禅道

    禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

    10 引用 • 15 回帖 • 4 关注
  • 服务

    提供一个服务绝不仅仅是简单的把硬件和软件累加在一起,它包括了服务的可靠性、服务的标准化、以及对服务的监控、维护、技术支持等。

    41 引用 • 24 回帖 • 2 关注