纯css车牌倾斜矫正的方法 css图像透视变换

简介: 纯css车牌倾斜矫正的方法 css图像透视变换

主要使用css里面transform的rotate和skew,一个是旋转,一个形变。我们先来看看概念:

rotate()


CSS 的 rotate() 函数定义了一种将元素围绕一个定点(由transform-origin属性指定)旋转而不变形的转换。指定的角度定义了旋转的量度。若角度为正,则顺时针方向旋转,否则逆时针方向旋转。旋转 180° 也被称为点反射。

语法<angle> 指定了 rotate() 的旋转程度。参数为正时,顺时针旋转;参数为负时,逆时针旋转。180° 旋转称为点反演

skew()


skew() 函数定义了一个元素在二维平面上的倾斜转换。

这种转换是一种剪切映射 (横切),它在水平和垂直方向上将单元内的每个点扭曲一定的角度。每个点的坐标根据指定的角度以及到原点的距离,进行成比例的值调整;因此,一个点离原点越远,其增加的值就越大。

语法skew() 函数指定一个或两个参数,它们表示在每个方向上应用的倾斜量。

接下来我们开始


为了测试在百度里找了个典型的倾斜的图,如下:

image.png

第1步:测量水平偏移角度


经过测量大概是13度。

image.png

我们使用代码transform:rotate(-13deg)得到如下结果:

image.png

第2步:继续在上面的结果上测量形变度数:


经过测量大概是16度。

image.png

再进一步加上transform:skew(-16deg)就得到了:

image.png

完整代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <title>CSStransform的应用-校正车牌</title>
<style>
  .img{transform:rotate(-13deg) skew(-16deg);}
</style>
</head>
<body>
    <img src="https://ucc.alicdn.com/images/user-upload-01/20200517195232687.jpg" alt="">
    <img class="img" src="https://ucc.alicdn.com/images/user-upload-01/20200517195232687.jpg">
</body>
</body>
</html>

ps:有些网友问如何自动得到13°和16°这两个数值,目前我还没有办法,我想这个只能通过人工智能识别图片中车牌位置,然后自动计算水平和垂直偏移度数来实现了,以上的方法只是抛砖引玉。

拓展:如果对于下面这样一点透视的图片,以上方法并没有效果,不知道用css如何实现,如果有知道的大神可以留言告知一下。

image.png

要是css能有像ps那种4点定位的方式的方式就好了,那样就方便多了,只要通过智能识别到车牌的4个顶点即可一步到位矫正了。希望w3c组织下次制定标准时能为css加上这个特性。

c1000a3feb754a1cbc5ef6d4134e6e8d_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.jpg

f6ccda22584145fbb60f9116b60b44d9_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.jpg


目录
相关文章
|
前端开发
css页面顶部底部固定,中间自适应几种方法
【10月更文挑战第22天】css页面顶部底部固定,中间自适应几种方法
|
缓存 监控 前端开发
CSS 提高性能的方法
【10月更文挑战第24天】在实际应用中,还需要根据具体项目的特点和需求,灵活选择和组合这些方法,不断进行优化和改进。同时,随着技术的不断发展,也需要持续关注新的性能优化技巧和最佳实践,以保持在性能优化方面的领先地位。你对 CSS 性能优化还有哪些深入的思考和经验呢?欢迎进一步交流和分享。
|
前端开发 容器
CSS 中几种常用的换行方法
CSS 中几种常用的换行方法
601 2
|
XML 前端开发 JavaScript
jQuery HTML / CSS 方法
jQuery HTML / CSS 方法
148 2
|
前端开发 JavaScript
jQuery css() 方法
jQuery css() 方法
211 3
|
前端开发 JavaScript
jQuery css() 方法
jQuery css() 方法
108 1
|
前端开发 容器
css溢出隐藏的五种方法
css溢出隐藏的五种方法
329 1
|
前端开发 UED
css性能优化的方法
css性能优化的方法
230 0
|
前端开发
CSS绘制三角形的方法
CSS绘制三角形的方法
|
前端开发
css 实用技巧 —— div在div中水平垂直居中(两种方法)
css 实用技巧 —— div在div中水平垂直居中(两种方法)
555 3

热门文章

最新文章

  • 1
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
    420
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
    330
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
    304
  • 4
    (CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
    205
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
    421
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
    608
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
    776
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
    214
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
    621
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
    382