❤️创意网页:能量棒页面 - 可爱版(加载进度条)

news2024/11/16 15:25:56

博主:命运之光 

🌸专栏:Python星辰秘典

🐳专栏:web开发(简单好用又好看)

❤️专栏:Java经典程序设计

☀️博主的其他文章:点击进入博主的主页

前言:欢迎踏入我的Web项目专栏,一段神奇而令人陶醉的数字世界!

🌌在这里,我将带您穿越时空,揭开属于Web的奥秘。通过HTML、CSS和JavaScript的魔力,我创造了一系列令人惊叹的Web项目,它们仿佛是从梦境中涌现而出。

🌌在这个专栏中,您将遇到华丽的界面,如流星划过夜空般迷人;您将感受到动态的交互,如魔法般让您沉浸其中;您将探索响应式设计的玄妙,让您的屏幕变幻出不同的绚丽景象。

🌌无论您是一个探险家还是一位嗜血的代码巫师,这个专栏将成为您的魔法书。我将分享每个项目的秘密,解开编码的谜题,让您也能够拥有制作奇迹的力量。

🌌准备好了吗?拿起您的键盘,跟随我的指引,一起进入这个神秘而充满惊喜的数字王国。在这里,您将找到灵感的源泉,为自己创造出一段奇幻的Web之旅!

目录

介绍

动态图展示

静态图展示

图片1

图片2

准备工作

HTML 结构

JavaScript 代码

绘制能量棒

更新加载进度

模拟加载过程

运行效果

完整代码

代码的使用方法(超简单什么都不用下载)

🍓1.打开记事本 

🍓2.将上面的源代码复制粘贴到记事本里面将文件另存为HTML文件点击保存即可

🍓3.打开html文件(大功告成(●'◡'●))

总结


介绍

在本技术博客中,我们将学习如何使用HTML5 Canvas和JavaScript创建一个可爱版的能量棒加载页面。我们将绘制一个带有彩虹光晕效果的能量棒,并通过模拟加载过程来展示加载进度。通过本项目,您将了解如何使用Canvas绘制动态效果,并运用可爱的彩虹字符和光晕效果,增添页面的趣味性。


动态图展示


静态图展示

图片1

图片2


准备工作

在开始之前,请确保您已经具备以下条件:

  • 基本的HTML、CSS和JavaScript知识。
  • 一个支持HTML5的现代web浏览器(推荐使用最新版本的Chrome、Firefox、Safari等)。

HTML 结构

首先,让我们创建一个HTML文件,并添加必要的结构。

<!DOCTYPE html>
<html>
<head>
    <title>能量棒加载页面 - 可爱版</title>
    <style>
        /* ... 上面的CSS代码 ... */
    </style>
</head>
<body>
    <div class="progress-container">
        <canvas id="energyBarCanvas" width="400" height="30"></canvas>
        <div class="loading-text">🌈 loading 0%</div>
    </div>
    <script>
        // JavaScript代码将在下面添加
    </script>
</body>
</html>

在这个HTML结构中,我们定义了一个Canvas元素和一个显示加载进度的容器。


JavaScript 代码

现在,让我们添加JavaScript代码来实现这个可爱版的能量棒加载页面。

<!-- ... 上面的HTML代码 ... -->

<script>
    // 获取Canvas元素和上下文
    const canvas = document.getElementById('energyBarCanvas');
    const ctx = canvas.getContext('2d');

    // 能量棒的宽度和高度
    const barWidth = canvas.width;
    const barHeight = canvas.height;

    // 加载进度(0-100)
    let progress = 0;

    // 设置能量棒的颜色和背景颜色
    const barColor = '#FF69B4'; // 热情粉红色
    const bgColor = '#FEE2E2'; // 淡粉色背景

    // 绘制能量棒的函数
    function drawEnergyBar() {
        // ... 绘制能量棒的代码 ...
    }

    // 更新加载进度并重绘能量棒
    function updateProgress(newProgress) {
        // ... 更新加载进度的代码 ...
    }

    // 模拟加载过程,每30毫秒增加一点加载进度
    function simulateLoading() {
        // ... 模拟加载过程的代码 ...
    }

    // 开始加载
    simulateLoading();
</script>
</body>
</html>

在这部分代码中,我们定义了绘制能量棒、更新加载进度和模拟加载过程的函数。接下来,我们将实现这些功能。


绘制能量棒

让我们编写绘制能量棒的函数,并在Canvas上绘制能量棒。

// 绘制能量棒的函数
function drawEnergyBar() {
    // 清空Canvas
    ctx.clearRect(0, 0, barWidth, barHeight);

    // 绘制背景矩形
    ctx.fillStyle = bgColor;
    ctx.fillRect(0, 0, barWidth, barHeight);

    // 添加渐变效果
    const gradient = ctx.createLinearGradient(0, 0, barWidth, 0);
    gradient.addColorStop(0, '#FF69B4');
    gradient.addColorStop(1, '#FF00FF');

    // 绘制能量棒
    ctx.fillStyle = gradient;
    ctx.fillRect(0, 0, barWidth * (progress / 100), barHeight);

    // 绘制🍓字符光晕效果
    ctx.fillStyle = 'rgba(255, 105, 180, 0.5)'; // 粉红色光晕效果
    ctx.font = '30px Arial';
    ctx.fillText('🐢', barWidth * (progress / 100) - 15, barHeight / 2 + 10);

    // 获取进度文字的元素
    const loadingText = document.querySelector('.loading-text');

    // 更新进度文字内容
    loadingText.textContent = `🌈 loading ${progress}%`; // 可爱的彩虹字符
}

在这段代码中,我们使用Canvas绘制了一个能量棒,其中背景为淡粉色,能量棒的颜色为热情粉红色。通过添加渐变效果,我们使能量棒呈现出彩虹色的效果。为了增加趣味性,我们在能量棒的末尾绘制了一个🍓字符,并给它添加了粉红色的光晕效果。


更新加载进度

接下来,我们编写更新加载进度并重绘能量棒的函数。

// 更新加载进度并重绘能量棒
function updateProgress(newProgress) {
    if (newProgress >= 0 && newProgress <= 100) {
        progress = newProgress;
        drawEnergyBar();
    }
}

这个函数接受一个新的加载进度值(0-100),然后更新进度,并重新绘制能量棒。


模拟加载过程

最后,我们模拟加载过程,每30毫秒增加一点加载进度。

// 模拟加载过程,每30毫秒增加一点加载进度
function simulateLoading() {
    const interval = setInterval(() => {
        updateProgress(progress + 1);
        if (progress === 100) {
            clearInterval(interval);
        }
    }, 30);
}

// 开始加载
simulateLoading();

在这段代码中,我们使用setInterval函数,每隔30毫秒增加1点加载进度,并通过调用updateProgress函数更新进度并重新绘制能量棒。当进度达到100%时,我们使用clearInterval函数停止加载过程。


运行效果

将上述HTML代码保存为一个HTML文件,并在支持HTML5的现代web浏览器中打开它。您将会看到一个可爱版的能量棒加载页面,粉红色的能量棒随着加载进度增长,同时伴随着可爱的彩虹字符和光晕效果,增添页面的趣味性。


完整代码

<!DOCTYPE html>
<html>
<head>
    <title>能量棒加载页面 - 可爱版</title>
    <style>
        body {
            display: flex;
            justify-content: center;
            align-items: center;
            height: 100vh;
            margin: 0;
            background-color: #FEE2E2; /* 淡粉色背景 */
            color: #FF69B4; /* 热情粉红文字颜色 */
            font-family: 'Arial', sans-serif;
        }
        .progress-container {
            display: flex;
            flex-direction: column;
            align-items: center;
        }
        canvas {
            border: 2px solid #FF69B4; /* 热情粉红边框 */
            box-shadow: 0px 0px 20px rgba(255, 105, 180, 0.3); /* 粉红色阴影 */
            border-radius: 20px; /* 圆角边框 */
        }
        .loading-text {
            font-size: 20px;
            margin-top: 10px;
            font-weight: bold; /* 加粗字体 */
        }
    </style>
</head>
<body>
    <div class="progress-container">
        <canvas id="energyBarCanvas" width="400" height="30"></canvas>
        <div class="loading-text">🌈 loading 0%</div> <!-- 可爱的彩虹字符 -->
    </div>

    <script>
        // 获取Canvas元素和上下文
        const canvas = document.getElementById('energyBarCanvas');
        const ctx = canvas.getContext('2d');

        // 能量棒的宽度和高度
        const barWidth = canvas.width;
        const barHeight = canvas.height;

        // 加载进度(0-100)
        let progress = 0;

        // 设置能量棒的颜色和背景颜色
        const barColor = '#FF69B4'; // 热情粉红色
        const bgColor = '#FEE2E2'; // 淡粉色背景

        // 绘制能量棒的函数
        function drawEnergyBar() {
            // 清空Canvas
            ctx.clearRect(0, 0, barWidth, barHeight);

            // 绘制背景矩形
            ctx.fillStyle = bgColor;
            ctx.fillRect(0, 0, barWidth, barHeight);

            // 添加渐变效果
            const gradient = ctx.createLinearGradient(0, 0, barWidth, 0);
            gradient.addColorStop(0, '#FF69B4');
            gradient.addColorStop(1, '#FF00FF');

            // 绘制能量棒
            ctx.fillStyle = gradient;
            ctx.fillRect(0, 0, barWidth * (progress / 100), barHeight);

            // 绘制🍓字符光晕效果
            ctx.fillStyle = 'rgba(255, 105, 180, 0.5)'; // 粉红色光晕效果
            ctx.font = '30px Arial';
            ctx.fillText('🐢', barWidth * (progress / 100) - 15, barHeight / 2 + 10);

            // 获取进度文字的元素
            const loadingText = document.querySelector('.loading-text');

            // 更新进度文字内容
            loadingText.textContent = `🌈 loading ${progress}%`; // 可爱的彩虹字符
        }

        // 更新加载进度并重绘能量棒
        function updateProgress(newProgress) {
            if (newProgress >= 0 && newProgress <= 100) {
                progress = newProgress;
                drawEnergyBar();
            }
        }

        // 模拟加载过程,每30毫秒增加一点加载进度
        function simulateLoading() {
            const interval = setInterval(() => {
                updateProgress(progress + 1);
                if (progress === 100) {
                    clearInterval(interval);
                }
            }, 30);
        }

        // 开始加载
        simulateLoading();
    </script>
</body>
</html>

代码的使用方法(超简单什么都不用下载)

🍓1.打开记事本 

🍓2.将上面的源代码复制粘贴到记事本里面将文件另存为HTML文件点击保存即可

🍓3.打开html文件(大功告成(●'◡'●))


总结

在本篇博客中,我们学习了如何使用HTML5 Canvas和JavaScript创建一个可爱版的能量棒加载页面。通过绘制能量棒和添加彩虹字符和光晕效果,我们成功地打造了一个有趣的加载页面。

希望这个简单而有趣的项目能够激发您创造更多有趣效果的灵感。感谢您的阅读,祝您编程愉快!


本章的内容就到这里了,觉得对你有帮助的话就支持一下博主把~

🌌点击下方个人名片,交流会更方便哦~
↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓

 

 

 

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/810470.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

电动汽车集群并网的分布式鲁棒优化调度模型(Matlab代码实现)

目录 &#x1f4a5;1 概述 &#x1f4da;2 运行结果 &#x1f389;3 参考文献 &#x1f308;4 Matlab代码实现 &#x1f4a5;1 概述 文献来源&#xff1a; 随着可再生能源&#xff08;Renewable Energy Source, RES&#xff09;的渗透率不断提高&#xff0c;RES 固有的间歇性对…

【RabbitMQ】Linux系统服务器安装RabbitMQ

一、下载 首先应该下载erlang&#xff0c;rabbitmq运行需要有erland环境。 官网地址&#xff1a;https://www.erlang.org/downloads 下载rabbitmq 官网环境&#xff1a;https://www.rabbitmq.com/download.html 注意&#xff1a;el7对应centos7&#xff0c;el8对应centos8…

机器学习:混合高斯聚类GMM(求聚类标签)+PCA降维(3维降2维)习题

使用混合高斯模型 GMM&#xff0c;计算如下数据点的聚类过程&#xff1a; Datanp.array([1,2,6,7]) 均值初值为: μ1,μ21,5 权重初值为: w1,w20.5,0.5 方差: std1,std21,1 K2 10 次迭代后数据的聚类标签是多少&#xff1f; 采用python代码实现&#xff1a; from scipy import…

iOS开发-CABasicAnimation实现小球左右摆动动画效果

iOS开发-CABasicAnimation实现小球左右摆动动画效果 之前开发中遇到需要实现小球左右摆动动画效果&#xff0c;这里作下记录。 一、效果图 二、实现代码 2.1 CABasicAnimation CABasicAnimation基础动画&#xff0c;包括duration、repeatCount、repeatDuration、beginTime、…

Java中对Redis的常用操作

目录 数据类型五种常用数据类型介绍各种数据类型特点 常用命令字符串操作命令哈希操作命令列表操作命令集合操作命令有序集合操作命令通用命令 在Java中操作RedisRedis的Java客户端Spring Data Redis使用方式介绍环境搭建配置Redis数据源编写配置类&#xff0c;创建RedisTempla…

JavaEE—— Callable接口、JUC的常见类、线程按安全的集合类(八股)

文章目录 一、Callable 接口二、JUC的常见类1. ReentrantLock2. 原子类(简单知晓)3.信号量 Semaphore4.CountDownLatch(简单了解) 三、线程安全的集合类1.多线程环境使用 ArrayList2.多线程使用哈希表 一、Callable 接口 Callable 接口类似于 Runnable 接口 Runnable 接口用来…

当阿里面试官问什么是hash?什么是布隆过滤器?什么是一致性hash?看这一篇就够了,很肝!也很干!

算法拾遗三十六hash 哈希函数特点hash表设计布隆过滤器布隆过滤器三大公式最终求解公式 一致性哈希经典数据存储经典hash缺点及解决方案虚拟节点 哈希函数特点 输入&#xff1a;任意长度字符串&#xff08;输入域无穷大&#xff09; 输出&#xff1a;相对有限 哈希函数无任何随…

前端,js , Error in created hook: TypeError ,有bug了

怎么兄弟&#xff0c;遇到bug了&#xff1f;&#xff1f;&#xff1f;你开心吗&#xff0c;哈哈哈哈

Linux操作系统1-命令篇

不同领域的主流操作系统 桌面操作系统 Windos Mac os Linux服务器操作系统 Unix Linux(免费、稳定、占有率高) Windows Server移动设备操作系统 Android(基于Linux,开源) ios嵌入式操作系统 Linux(机顶盒、路由器、交换机) Linux 特点&#xff1a;免费、开源、多用户、多任务…

【C/C++】#include<xxx.h>和#include“xxx.h“之间的区别以及寻找gcc和g++的系统头文件目录和系统库文件目录的方法

2023年7月29日&#xff0c;周六晚上 今天下午和晚上花了不少时间去研究这个C/C的头文件以及#include<xxx.h>和#include"xxx.h"之间的区别&#xff0c;收获到了很多的很有用的知识。非常值得花时间来以博客的形式总结这些学习成果。 说实话&#xff0c;我挺想…

python美化图形化界面设计,pythontkinter界面美化

大家好&#xff0c;本文将围绕python美化图形化界面设计展开说明&#xff0c;pythontkinter界面美化是一个很多人都想弄明白的事情&#xff0c;想搞清楚python美化输出模块需要先了解以下几个事情。 1、python如何做界面 PyQt&#xff0c;一个基于Qt的Python接口包&#xff0c…

网络框架重构之路plain2.0(c++23 without module) 综述

原因 plain1.1rc的不足 &#xff11;、命名空间问题 如果看过或者接触过plain的朋友&#xff0c;不难发现命名空间都是以pf_*开头。说起这个的时候&#xff0c;还是要从plain的前身plainserver&#xff08;GitHub - viticm/plainserver: A plain server, simple but stronger.&…

SpringBoot超级详解

1.父工程的父工程 在父工程的父工程中的核心依赖&#xff0c;专门用来版本管理的 版本管理。 2.父工程 资源过滤问题&#xff0c;都帮解决了&#xff0c;什么配置文件&#xff0c;都已经配置好了&#xff0c;资源过滤问题是帮助&#xff0c;过滤解决让静态资源文件能够过滤到…

HCIP OSPF链路状态类型总结

OSPF的LSA OSPF是典型的链路状态路由协议&#xff0c;使用LAS&#xff08;链路状态通告&#xff09;来承载链路状态信息。LSA是OSPF的一个核心内容&#xff0c;如果没有LSA&#xff0c;OSPF 是无法描述网络的拓扑结构及网段信息的&#xff0c;也无法传递路由信息&#xff0c;更…

跟老齐学python:数据分析,python数据分析开源软件

大家好&#xff0c;小编来为大家解答以下问题&#xff0c;python数据分析安装什么软件&#xff0c;python数据分析模块如何用&#xff0c;现在让我们一起来看看吧&#xff01;

百题千解计划【CSDN每日一练】收件邮箱(使用Python、Java、JavaScript解决)无敌的Python正则表达式、零宽负向断言

天真的人,不代表没有见过世界的黑暗,恰恰因为见到过,才知道天真的好。———三毛 🎯作者主页: 追光者♂🔥 🌸个人简介: 💖[1] 计算机专业硕士研究生💖 🌟[2] 2022年度博客之星人工智能领域TOP4🌟 🏅[3] 阿里云社区特邀专家博主🏅 🏆…

25.10 matlab里面的10中优化方法介绍—— 函数fmincon(matlab程序)

1.简述 关于非线性规划 非线性规划问题是指目标函数或者约束条件中包含非线性函数的规划问题。 前面我们学到的线性规划更多的是理想状况或者说只有在习题中&#xff0c;为了便于我们理解&#xff0c;引导我们进入规划模型的一种情况。相比之下&#xff0c;非线性规划会更加贴近…

开发集成工具pre-commit详解介绍

文章目录 pre-commit简介安装使用安装pre-commit脚本 pre-commit 官网-使用介绍 官网-可使用的钩子列表 简介 pre-commit&#xff1a;帮助你提高代码质量的工具 pre-commit是一个帮助开发人员提高代码质量的工具。它通过在提交代码之前运行一系列检查来实现这一点。这些检…

【并发编程】ForkJoinPool工作原理分析

目录 前置内容课程内容一、由一道算法题引发的思考1.算法题2.什么是归并排序法 二、什么是Fork/Join框架1.基本介绍2.ForkJoinPool2.ForkJoinPool构造函数及参数解读3.任务提交方式4.工作原理图5.工作窃取6.和普通线程池之间的区别7.ForkJoinTask 学习总结 前置内容 Q1&#x…

数学建模学习(7):Matlab绘图

一、二维图像绘制 1.绘制曲线图 最基础的二维图形绘制方法&#xff1a;plot -plot命令自动打开一个图形窗口Figure&#xff1b; 用直线连接相邻两数据点来绘制图形 -根据图形坐标大小自动缩扩坐标轴&#xff0c;将数据标尺及单位标注自动加到两个坐标轴上&#xff0c;可自定…