01.个人项目难点汇总3 箭头流动及油管流动特效

2023-11-20 19:50

本文主要是介绍01.个人项目难点汇总3 箭头流动及油管流动特效,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

01.简单实例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>流动箭头</title>
</head><style>/* 整个流动箭头的body */.arrow-body {position: relative;margin: 0;padding: 0;/* 这里修改整个流动箭头的长度 */width: 500px;/* 这里修改body的高度,注意:会影响三角箭头的形状 */height: 24px;overflow: hidden;}/* 三角箭头 */.arrow-body::after {content:"";position:absolute;/* 这里要和下面一起修改 */right: -12px;top: 0;width: 0;height: 0;/* 这里修改箭头的高度,这里建议是上面的24px的一半,同时要修改right:-12px的值 */border: 12px solid transparent;/* 这里可以修改箭头的横向长度,以及颜色 */border-left-width: 20px;border-left-color: skyblue;} /* 流动的线条的body */.flow-body {position: relative;margin: 0;padding: 0;height: 100%;width: calc(100% - 10px);overflow: hidden;}/* 线条样式 */.flow-body::before {content:"";position: absolute;width: 200%;/* 这里修改线条的高度,同时top减去的值是高度的一半(为了保持垂直居中) */height: 6px;top: calc(50% - 3px);/* 这里修改线条的颜色(可以达到渐变) */background: repeating-linear-gradient(90deg,skyblue 0,skyblue 15px,rgba(0,0,0,0) 15px,rgba(0,0,0,0) 20px);transform: translateX(-100%);animation: flow linear 8s infinite;}/* 流动动画 */@keyframes flow {from {transform:translateX(-50%);}to {transform:translateX(0);}}</style><body><div class="flow-arrow"><div class="arrow-body"><div class="flow-body"></div></div></div></body>
</html>

在这里插入图片描述

02.DEH项目流动油管

01.需求分析

封装流动管道动画功能:

  • 设置动画的起点和终点 宽度和高度暂时定死
  • 有横版和竖版两种方式进行选择
  • 可以选择流动方向
  • 流动的速度可调
  • 可以选择头部尾部是否添加弧形
    • 弧形可选择左边还是右边
  • 油管分为静态白色油管和动态油管

02.css初步实现代码

01.油管横向向右滑动

html

<div class="arrow-body"><div class="flow-body blcak-border"></div>
</div>

css

/* 整个流动箭头的body */
.arrow-body {
position: absolute;
margin: 0;
padding: 0;
/* 这里修改整个流动箭头的长度和高度 */
width: calc(409vw * 100 / 1920);
height: calc(10vh * 100 / 1080);
overflow: hidden;
}
/* 流动的线条的body */
.flow-body {
position: relative;
margin: 0;
padding: 0;
height: 100%;
width: 100%;
overflow: hidden;
border: calc(2vh * 100 / 1080) solid #00eaf7;
}
/* 线条样式 */
.flow-body::before {
content: "";
position: absolute;
width: 200%;
/* 这里修改线条的高度,同时top减去的值是高度的一半(为了保持垂直居中) */
height: 30%;
top: 35%;
/* 这里修改线条的颜色(可以达到渐变) */
background: repeating-linear-gradient(90deg,skyblue 0,skyblue calc(5vw * 100 / 1920),#01155d calc(5vw * 100 / 1920),#01155d calc(10vw * 100 / 1920)
);
animation: flow linear 8s infinite;
}
/* 横向流动动画 右*/
@keyframes flow {
from {transform: translateX(-50%);
}
to {transform: translateX(0);
}
}

flow

02.油管横向向左滑动

直接改变动画函数帧即可,其他不做变动

.arrow-body:nth-child(4) .flow-body::before {
animation: flowRight linear 2s 0;
}
@keyframes flowRight {
from {transform: translateX(0%);
}
to {transform: translateX(-50%);
}
}

flowLeft

03.纵向油管向下滑动

.arrow-body{
position: absolute;
margin: 0;
padding: 0;
/* 这里修改整个流动箭头的长度和高度 */
left: calc(793vw * 100 / 1920);
top: calc(44vh * 100 / 1080);
/* 这里修改整个流动箭头的长度和高度 */
width: calc(10vw * 100 / 1920);
height: calc(82vh * 100 / 1080);
overflow: hidden;
}
.arrow-body .flow-body {
border-radius: 0 20px 0 0;
}
.arrow-body .flow-body::before {
content: "";
/* content: "5";
color: red; */
position: absolute;
border-radius: 0 50% 0 0;
top: 0;
width: 30%;
/* 这里修改线条的高度,同时top减去的值是高度的一半(为了保持垂直居中) */
height: 200%;
right: 35%;
/* 这里修改线条的颜色(可以达到渐变) */
background: repeating-linear-gradient(180deg,skyblue 0,skyblue calc(5vw * 100 / 1920),#01155d calc(5vw * 100 / 1920),#01155d calc(10vw * 100 / 1920)
);
animation: flowDown linear 8s 0;
}

04.纵向油管向上滑动

/* 纵向流动动画 上*/
@keyframes flowUp {
from {transform: translateY(0%);
}
to {transform: translateY(-50%);
}
}

05.油管添加圆角

直接修改放款圆角即可

  • 右上圆角 其他类比
.arrow-body:nth-child(5) .flow-body {border-radius: 0 20px 0 0;
}

03.scss封装

/* 抽离统一代码 $direection为 1代表横向  0代表纵向*/
@mixin framFlow($direction, $startPosition, $endPosition) {from {transform: if($direction, translateX($startPosition), translateY($startPosition));}to {transform: if($direction, translateX($endPosition), translateY($endPosition));}
}
@keyframes flowRight {@include framFlow(1, -50%, 0);
}
/* 横向流动动画 左*/
@keyframes flowLeft {@include framFlow(1, 0%, -50%);
}
/* 纵向流动动画 下*/
@keyframes flowDown {@include framFlow(0, -50%, 0%);
}
/* 纵向流动动画 上*/
@keyframes flowUp {@include framFlow(0, 0%, -50%);
}
/* 注:使用此函数时 父元素需不为标准流定位$shape 决定油管形状 0代表横向 1代表纵向$direction 决定油管方向 left代表向左 right代表向右 up代表向上 down代表向下$distence 横向时 决定油管的纵坐标处于距上方多少 纵向时,决定油管距左边多少$startPosition 决定油管起点 横向时从左到右 终向时从上到下$endPosition 决定油管终点$speed 决定动画速度$radiusPosition 决定是否添加圆角$style 决定油管风格 实际上就是边框颜色*/
@mixin flow-animation($shape,$direction,$distence,$startPosition,$endPosition,$speed,$radiusPosition: "none",$style: #00eaf7
) {position: absolute;/* 根据不同形状判断此时油管位置 */@if $shape == 0 {left: $startPosition;top: $distence;} @else {left: $distence;top: $startPosition;}margin: 0;padding: 0;/* 这里根据$shape修改矩形大小 0代表横向 1代表纵向*/@if $shape == 0 {/* 横向时宽为终点-起点 */width: $endPosition - $startPosition;/* 横向时高固定 */height: calc(10 * var(--flexHeight));} @else {/* 纵向时宽固定 */width: 1rem;/* 纵向时高为 终点-起点 */height: $endPosition - $startPosition;}overflow: hidden;/* 流动的线条的body */.flow-body {position: relative;margin: 0;padding: 0;height: 100%;width: 100%;overflow: hidden;border: calc(2 * var(--flexHeight)) solid $style;/* 判断是否添加圆角 */@if $radiusPosition == "top-left" {border-radius: 20px 0 0 0;} @else if $radiusPosition == "top-right" {border-radius: 0 20px 0 0;} @else if $radiusPosition == "bottom-left" {border-radius: 0 0 0 20px;} @else if $radiusPosition == "bottom-right" {border-radius: 0 0 20px 0;} @else {border-radius: 0;}&::before {content: "";position: absolute;@if $shape == 0 {width: 200%;/* 这里修改线条的高度,同时top减去的值是高度的一半(为了保持垂直居中) */height: 30%;top: 35%;left: 0;/* 这里修改线条的颜色(可以达到渐变) */background: repeating-linear-gradient(90deg,skyblue 0,skyblue calc(5vw * 100 / 1920),#01155d calc(5vw * 100 / 1920),#01155d calc(10vw * 100 / 1920));} @else {top: 0;width: 30%;/* 这里修改线条的高度,同时top减去的值是高度的一半(为了保持垂直居中) */height: 200%;right: 35%;/* 这里修改线条的颜色(可以达到渐变) */background: repeating-linear-gradient(180deg,skyblue 0,skyblue calc(5vw * 100 / 1920),#01155d calc(5vw * 100 / 1920),#01155d calc(10vw * 100 / 1920));}@if $direction == "right" {animation: flowRight linear $speed infinite;} @else if $direction == "left" {animation: flowLeft linear $speed infinite;} @else if $direction == "up" {animation: flowUp linear $speed infinite;} @else {animation: flowDown linear $speed infinite;}}}
}
/* 定义流动动画 *//* 横向流动动画 右*/
@keyframes flowRight {from {transform: translateX(-50%);}to {transform: translateX(0);}
}
/* 横向流动动画 左*/
@keyframes flowLeft {from {transform: translateX(0);}to {transform: translateX(-50%);}
}
/* 纵向流动动画 下*/
@keyframes flowDown {from {transform: translateY(-50%);}to {transform: translateY(0%);}
}
/* 纵向流动动画 上*/
@keyframes flowUp {from {transform: translateY(0%);}to {transform: translateY(-50%);}
}
/* 统一的样式 */
.arrow-body {@include flow-animation(1,"down",30px,30px,200px,0s,"bottom-right",#cecece);
}
.arrow-body:nth-child(1) {@include flow-animation(1, "up", 300px, 30px, 200px, 8s, "top-right");
}
.arrow-body:nth-child(2) {@include flow-animation(0, "left", 400px, 30px, 200px, 8s, "top-right");
}

最终的展示效果
flowFinal

这篇关于01.个人项目难点汇总3 箭头流动及油管流动特效的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/397027

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

hdu 2602 and poj 3624(01背包)

01背包的模板题。 hdu2602代码: #include<stdio.h>#include<string.h>const int MaxN = 1001;int max(int a, int b){return a > b ? a : b;}int w[MaxN];int v[MaxN];int dp[MaxN];int main(){int T;int N, V;s

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

SpringBoot项目是如何启动

启动步骤 概念 运行main方法,初始化SpringApplication 从spring.factories读取listener ApplicationContentInitializer运行run方法读取环境变量,配置信息创建SpringApplication上下文预初始化上下文,将启动类作为配置类进行读取调用 refresh 加载 IOC容器,加载所有的自动配置类,创建容器在这个过程

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免

2. 下载rknn-toolkit2项目

官网链接: https://github.com/airockchip/rknn-toolkit2 安装好git:[[1. Git的安装]] 下载项目: git clone https://github.com/airockchip/rknn-toolkit2.git 或者直接去github下载压缩文件,解压即可。

集中式版本控制与分布式版本控制——Git 学习笔记01

什么是版本控制 如果你用 Microsoft Word 写过东西,那你八成会有这样的经历: 想删除一段文字,又怕将来这段文字有用,怎么办呢?有一个办法,先把当前文件“另存为”一个文件,然后继续改,改到某个程度,再“另存为”一个文件。就这样改着、存着……最后你的 Word 文档变成了这样: 过了几天,你想找回被删除的文字,但是已经记不清保存在哪个文件了,只能挨个去找。真麻烦,眼睛都花了。看