css实现任意大小、方向和角度的箭头代码

本文主要和大家介绍了使用css实现任意大小、任意方向和任意角度的箭头示例的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考,希望能帮助到大家。

网页开发中,经常会使用到 下拉箭头

css实现任意大小、方向和角度的箭头代码

,右侧箭头

css实现任意大小、方向和角度的箭头代码

立即学习“前端免费学习笔记(深入)”;

这样的箭头。 一般用css来实现:

{          display: inline-block;          margin: 72px;          border-top: 24px solid;        border-right: 24px solid;          width: 120px;        height: 120px;          transform: rotate(45deg);     }

因为这是利用p的border-top, border-right,然后通过旋转p来实现的。

任意角度的箭头

这里有个问题: 假如需要一个角度为120度的箭头怎么办呢? 由于border-top, border-right一直是90度, 所以仅仅通过旋转不行。 我们可以先把p 旋转45度, 让它成为一个 菱形 然后再伸缩,达到任意的角度, 这样就可以得到一个 任意角度的箭头。由于用到了旋转和伸缩两种变换,所以需要使用 transform: matrix(a,b,c,d,e,f) 这个变换矩阵。 这里的6个变量组成了一个3介的变换矩阵

任意点p(x,y)的平移, 旋转, 伸缩变换以及他们的各种组合都可以通过这个变换矩阵做到:

注:这里用齐次坐标 来表达一个点。 简单说就是p(x, y) 表示为p'(x’, y’, 1)

平移矩阵

v(x, y) 沿着x轴平移tx, 沿着y轴平移ty。 则有:

x’ = x + txy’ = y + ty

所以平移矩阵:

旋转矩阵

v(x, y) 点绕原点旋转θ到v'(x’, y’)

css实现任意大小、方向和角度的箭头代码

则有:

x = r * cos(ϕ )
y = r * sin(ϕ )

x’ = r * cos(θ + ϕ) = r * cos(θ) * cos(ϕ) – r * sin(θ) * sin(ϕ ) // 余弦公式
y’ = r * sin(θ + ϕ) = r * sin(θ) * cos(ϕ) + r * cos(θ) * sin(ϕ ) // 正弦公式

所以:

x’ = x * cos(θ) – y * sin(θ)
y’ = x * sin(θ) + y * cos(θ)

所以旋转矩阵:

伸缩矩阵

假设x轴,y轴的伸缩率分别是kx, ky。 则有:

x’ = x * kx
y’ = y * ky

所以:

复合变换

如果是对p(x, y)先平移(变换矩阵A), 然后旋转(变换矩阵B), 然后伸缩(变换矩阵C)呢?

p’ =C(B(Ap)) ==> p’ = (CBA)p //矩阵乘法结合率

现在任意角度o的箭头就很简单了:

先把p旋转45度 成为 菱形, 变换为 M1 伸缩x轴, y轴 :

x' = size * cos(o/2) = x * √2 *  cos(o/2)y' = size * sin(o/2) = y *  √2  * sin(o/2)

即: kx = √2 * cos(o/2); ky = √2 * sin(o/2) 这样就得到了任意角度的箭头。 变换为 M2

如果箭头的方向不是指向右侧, 在进行一次旋转就可以得到任意方向的箭头。变换为 M3

那么由于 p' =C(B(Ap)) ==> p' = (CBA)p , 我们就可以先计算出 M3 M2 M1,然后对p进行相应的变换,就可以得到任意角度, 任意方向的箭头了。

p的width和height就是箭头的边长, 通过调整可以获取任意边长的箭头。

React组件

为了方便使用, 这个箭头被封装为了一个 React组件。

示例 

简单箭头

css实现任意大小、方向和角度的箭头代码

模拟select

css实现任意大小、方向和角度的箭头代码

发散箭头

css实现任意大小、方向和角度的箭头代码

props

name type default description

degreenumber90箭头的张角, 角度制offsetDegreenumber0箭头的方向,默认指向右边colorstring-箭头的颜色sizestring10px箭头边长

安装使用

npm install rc-arrow --save

import Arrow from 'rc-arrow'class Hw extends Component {    render() {        return (                    )    }}

相关推荐:

纯CSS3实现网页中常见的小箭头实例

用css3制作网页中常见的小箭头的方法

JavaScript箭头函数的用法介绍

以上就是css实现任意大小、方向和角度的箭头代码的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1609004.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 00:31:00
下一篇 2025年12月24日 00:31:18

相关推荐

  • 5种css实现左中右布局的方式

    本文主要和大家介绍了css布局实现左中右布局的5种方式的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考,希望能帮助到大家。 效果如下: 左中右布局 Document html *{ margin: 0; padding: 0; } article{ height: 100px; } s…

    2025年12月24日
    000
  • CSS的伪类内容生成

    这次给大家带来css的伪类内容生成,css的伪类内容生成的注意事项有哪些,下面就是实战案例,一起来看一下。 1、 通过 css 向已有的元素上增加新的文本(图片)内容选择器:    1、:before     向匹配元素之前增加生成的内容     定位到匹配元素开始的位置    2、:after  …

    好文分享 2025年12月24日
    000
  • CSS计数器与多列的使用

    这次给大家带来css计数器与多列的使用,css计数器与多列使用的注意事项有哪些,下面就是实战案例,一起来看一下。 通过css 定义一个计数器,在其他元素中可以使用该计数器生成的数字。属性:  1、 counter-reset   作用:用于定义计数器并设置初始值   如果不设置初始值,那么默认为0,…

    好文分享 2025年12月24日
    000
  • css文件格式化脚本的方法

    这次给大家带来css文件格式化脚本的方法,css文件格式化脚本的注意事项有哪些,下面就是实战案例,一起来看一下。 #!/usr/bin/python# -*- coding: UTF-8 -*-import sys,osdef format(ddt): ddt = ddt.replace(‘n’,’…

    2025年12月24日
    000
  • Css多行字符截取方法详解

    相信有很多同学在写前端页面的时候,都会遇到字符长了需要截取的问题,最简单的方法就是手动去截取,可这样又感觉太low了,今天晚上就来讲讲利用css进行字符的截取,不了解css是如何截取的同学可以和我们一起看看哦! 前言 最近在做响应式系统设计的时候遇到需要对标题进行多行文字截取的效果,如下图: 看似十…

    2025年12月24日 好文分享
    000
  • CSS实现动态气泡背景代码分享

    本文主要和大家介绍了css 动画实现动态气泡背景的方法的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。 今天的第一个任务是写个登录页面,老大给了我一个参(chao)考(xi)案例,大家点击链接就能看到。嗯,这个登录页面确实很简洁、大方,尤其是…

    2025年12月24日
    000
  • CSS3通过@keyframes创建动画

    本文主要和大家介绍了css3 @keyframes简单动画实现的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。 定义: 通过 @keyframes 规则,能够创建动画。 创建动画的原理是,将一套 CSS 样式逐渐变化为另一套样式。 在动画过程…

    好文分享 2025年12月24日
    000
  • css3实现圆形旋转倒计时代码分享

    很多答题的h5界面上有旋转倒计时的效果,一个不断旋转减少的动画,类似于下图的这样。本文主要和大家介绍了css3 实现圆形旋转倒计时功能,需要的朋友可以参考下,希望能帮助到大家。 今天研究了下,可以通过border旋转得到。一般我们可以通过border得到一个四段圆。 See the Pen circ…

    2025年12月24日
    000
  • CSS 高级技巧汇总分享

    本文主要和大家分享CSS 高级技巧汇总,使用技巧会让人变的越来越懒,没错,我就是想让你变懒。下面是我收集的CSS高级技巧,希望你懒出境界。 1. 黑白图像 这段代码会让你的彩色照片显示为黑白照片,是不是很酷? img.desaturate { filter: grayscale(100%); -we…

    好文分享 2025年12月24日
    000
  • html和csss实现简单博客代码分享

    本文主要和大家分享html和csss实现简单博客代码,希望能帮助大家用HTML和css完成一个简单的博客。 过度动画 -webkit-transition: color 200ms; -o-transition: color 200ms; transition: color 200ms; 阴影 -w…

    好文分享 2025年12月24日
    000
  • CSS内边距外边距代码详解

    本文主要和大家分享css之内边距与外边距,本文运用了多个实例与代码,希望能帮助到大家。 外边距: margin 左边距 margin-left:数值 | autoauto:即距离这个边最远的距离右边距: margin-right:数值 | auto上边距: margin-top:数值 这里不能用au…

    2025年12月24日 好文分享
    000
  • CSS的Word中的列表详解

    在word中,列表也是使用频率非常高的元素。在css中,列表和列表项都是块级元素。也就是说,一个列表会形成一个块框,其中的每个列表项也会形成一个独立的块框。所以,盒模型中块框的所有属性,都适用于列表和列表项。 除此之外,列表还有 3 个特有的属性 list-style-type、list-style…

    2025年12月24日
    000
  • css垂直居中实现代码

    本文主要和大家分享css垂直居中实现代码,希望本文css代码能帮助到大家。 1.如果是单行文本, line-height 的值和height相等 案例如下: 立即学习“前端免费学习笔记(深入)”; .verticle{ height: 100px; line-height: 100px;} 2.已知…

    好文分享 2025年12月24日
    000
  • 纯CSS实现波浪移动效果

    本文主要介绍了纯css实现波浪移动效果的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。 在某些页面上常常看到波浪的效果,虽然只有装饰的作用,但是却让页面看上去更生动了,同时某些情况下也能起到进度条的作用,而波浪的形式却比普通进度条更美观有趣。 如…

    2025年12月24日
    000
  • css3怎么做幻灯片切换动画效果

    这次教大家的是怎样用css3做出幻灯片的切换动画效果,幻灯片的切换动画效果在很多情况下都可以用得到,今天就给大家一份幻灯片的切换动画效果的操作案例 html5 幻灯片切换动画 Black Widow Credits Credits Captain America Credits Credits Ir…

    好文分享 2025年12月23日
    000
  • DIV CSS规范命名总结

    正确并形象地给函数、变量命名,不仅可以增加程序的可读性,也是程序员编程风格的一种反映。较好的命名习惯,可以有效的提高程序的可维护性。以下介绍规范命名的方法,感兴趣的小伙伴们可以来看一下。 1. DIV+CSS规范命名集合 我们开发CSS+p网页(Xhtml)时候,比较困惑和纠结的事就是CSS命名,特…

    2025年12月23日
    000
  • css的hack技术使用汇总

    什么是css hack? 在web开发中,我们经常会遇到各浏览器表现不一致的情况,由于不同厂商的流览器或某浏览器的不同版本,对CSS的支持、解析不一样,导致在不同浏览器的环境中呈现出不一致的页面展现效果。这时,我们为了获得统一的页面效果,就需要针对不同的浏览器或不同版本写特定的CSS样式,我们把这个…

    好文分享 2025年12月23日
    000
  • 关于CSS中浮动属性的简单介绍

    要介绍css的float浮动属性,就必须先了解一下标准文档流 标准文档流:   在没有css的干预下,块级元素独占一行,可以设置宽高,行内元素并排显示,宽高自动填充。   HTML页面的标准文档流(默认布局)是:从上到下,从左到右,遇块(块级元素)换行。 float浮动属性最开始的用法是实现让目标内…

    好文分享 2025年12月23日
    000
  • 总结css边框实现各种效果的方法

    css中可以通过样式来改变边框的样式及颜色等,下面就来分享几篇关于改变边框的方法: 1.CSS深入理解之border视频教程 《CSS深入理解之border视频教程》将深入讲解CSS中的border属性,深入介绍border-color之间的关系,以及border与background定位、bord…

    2025年12月23日 好文分享
    000
  • css,css3实现各种图片效果总结

    按照常规的理解,处理图像的效果都应该是设计师的工具,甚至这些事情应该都交给photoshop之类的设计软件来完成。但是随着css技术的发展以及css3的出现,各大厂商的浏览器的兼容性越来越好,利用css技术来处理和实现图片的各种效果变得越来越便捷。css及css3中的各种属性将很容易的帮助我们实现各…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信