目录

  • 前言
  • 哈哈镜放大效果
  • 哈哈镜缩小效果
  • 直接视频实现哈哈镜效果

前言

在抖音中,我们经常看到各种抖音玩家都喜欢使用哈哈镜效果。那么什么是哈哈镜呢?

在现实生活中,哈哈镜是指一种表面凹凸不平的镜子,可以反应出人像及物体的扭曲面貌。简单点来说就是拉伸人脸(物件),或者压缩人脸(物体)的效果。

哈哈镜的实现原理如下:

假设输入图像的宽高为w和h,图像中心点的坐标为(cx,cy)。那么图像中任意一点(x,y)到中心点的距离为(x-cx),(y-cy)。

那么拉升放大,图像变换的半径为r(r是哈哈镜的范围大小),得到公式如下:

x=(tx/2)(sqrt(txtx+tyty)/r)+cx
y=(ty/2)
(sqrt(txtx+tyty)/r)+cy

同理,压缩缩小的公式如下(compress为压缩强度):
x=cos(atan2(ty,tx))compresssqrt(sqrt(txtx+tyty))+cx
y=cos(atan2(ty,tx))compresssqrt(sqrt(txtx+tyty))+cy

哈哈镜放大效果

既然我们了解了其数学公式以及其实现的原理,下面我们来直接实现哈哈镜的放大效果。具体代码如下所示:

#哈哈镜放大效果实现
def enlarge_effect(img):h, w, n = img.shapecx = w / 2cy = h / 2radius = 100#该值可以自行定义,它决定了哈哈镜的大小,当图像很大时,应该相应的调大r = int(radius / 2.0)new_img = img.copy()for i in range(w):for j in range(h):tx = i - cxty = j - cydistance = tx * tx + ty * tyif distance < radius * radius:x = int(int(tx / 2.0) * (math.sqrt(distance) / r) + cx)y = int(int(ty / 2.0) * (math.sqrt(distance) / r) + cy)if x < w and y < h:new_img[j, i, 0] = img[y, x, 0]new_img[j, i, 1] = img[y, x, 1]new_img[j, i, 2] = img[y, x, 2]return new_imgif __name__ == "__main__":img = cv2.imread("4.jpg")enlarge_img = enlarge_effect(img)cv2.imshow("4", enlarge_img)cv2.waitKey()cv2.destroyAllWindows()

运行之后,效果如下:

需要注意的是,上面的计算过程可能导致有浮点数的出现,而像素值必须为整数。所以,为了保证像素值的有效性,必须在计算过程完整之后,进行强制类型转换int()。另外,计算x,y值时,可能会导致超过图像坐标的范围,所以必须用x<w和y<h来判断防止越界。

哈哈镜缩小效果

下面我们直接实现哈哈镜的缩小效果。具体代码如下所示:

def reduce_effect(img):h, w, n = img.shapecx = w / 2cy = h / 2radius = 100r = int(radius / 2.0)compress = 8new_img = img.copy()for i in range(w):for j in range(h):tx = i - cxty = j - cyx = int(cx + (math.sqrt(math.sqrt(tx * tx + ty * ty)) * compress * math.cos(math.atan2(ty, tx))))y = int(cy + (math.sqrt(math.sqrt(tx * tx + ty * ty)) * compress * math.sin(math.atan2(ty, tx))))if x < 0 and x > w:x = 0if y < 0 and y > h:y = 0if x < w and y < h:new_img[j, i, 0] = img[y, x, 0]new_img[j, i, 1] = img[y, x, 1]new_img[j, i, 2] = img[y, x, 2]return new_imgif __name__ == "__main__":img = cv2.imread("4.jpg")enlarge_img = enlarge_effect(img)frame = reduce_effect(img)cv2.imshow("1", img)cv2.imshow("2", enlarge_img)cv2.imshow("3", frame)cv2.waitKey()cv2.destroyAllWindows()

运行之后,效果如下:

直接视频实现哈哈镜效果

抖音上面的哈哈镜都是动态的,并不是单一的图片这么变来变去。其实,只要我们集合前面的摄像头视频录制功能,就可以完成视频哈哈镜的动态效果。具体代码如下:

if __name__ == "__main__":cap = cv2.VideoCapture(0)while (cap.isOpened()):ret, frame = cap.read()frame=enlarge_effect(frame)cv2.imshow('video', frame)c = cv2.waitKey(1)if c == 27:breakcap.release()cv2.destroyAllWindows()

实现抖音哈哈镜效果---OpenCV-Python开发指南(47)相关推荐

  1. 干货 | 抖音漫画效果解密

    点击上方"小白学视觉",选择加"星标"或"置顶" 重磅干货,第一时间送达 本文转自:AI算法与图像处理 抖音漫画效果 要说最近抖音最火的效果 ...

  2. 抖音SEO排名优化源代码开发搭建技术分析

    抖音seo优化排名获客系统,抖音SEO系统源码开发,思路,给大家日常分享一些抖音seo源码的部署开发,抖音seo程序开发是目前很多开发公司都在搭建的系统.... 一套优秀的抖音seo短视频获客系统,支 ...

  3. 基于android的高仿抖音,Android仿抖音列表效果

    本文实例为大家分享了Android仿抖音列表效果的具体代码,供大家参考,具体内容如下 当下抖音非常火热,是不是也很心动做一个类似的app吗? 那我们就用RecyclerView实现这个功能吧,关于内存 ...

  4. 抖音seo源码.源代码开发可二开搭建/抖音seo优化系统代开发

    抖音seo源码源代码开发可二开搭建, 抖音seo源码,抖音seo矩阵系统源码技术搭建 抖音seo源码,抖音seo矩阵系统底层框架上支持了从ai视频混剪,视频批量原创产出,云端数字人视频制作,账号矩阵, ...

  5. 微信小程序实现抖音视频效果

    当我们进行开发的时候可能会遇到需要实现抖音视频效果的需求,并且网上该效果的开源代码少,找到的开源代码代码量大,很难进行二次开发 对此我将自己的代码进行简化,仅留下可动性高的代码模块 以上是实现效果与此 ...

  6. autojs模仿抖音logo效果

    牙叔教程 简单易懂 效果展示 为什么做 看到别人的头像是这种风格, 虽然我不会去修改自己的头像, 但是我想知道如何实现这样的效果, 虽然写出来了, 不过我感觉还是不完全像抖音的效果, 可能还缺点啥 环 ...

  7. 抖音矩阵,矩阵账号开发,抖音矩阵源码搭建

    抖音矩阵,矩阵账号开发,抖音矩阵源码搭建: 1.账号矩阵系统搭建首先需要注意的是支持多平台,多账号,可以实现流量互通,账号矩阵多个账号联动形成账号矩阵形式分发开发. 2.账号矩阵系统需要可以查看分发内 ...

  8. 引燃抖音短视频源码开发项目的几点原因

    抖音上线一年多,在经历了2018年春节之后,抖音的用户量从4000万保障了50%达到6000万量级.直到现在,抖音已经完全开启了"全民抖音"的时代,成为短视频行业发展的领头军,抖音 ...

  9. android仿抖音礼物列表实现,Android仿抖音列表效果

    本文实例为大家分享了Android仿抖音列表效果的具体代码,供大家参考,具体内容如下 当下抖音非常火热,是不是也很心动做一个类似的app吗? 那我们就用RecyclerView实现这个功能吧,关于内存 ...

最新文章

  1. ArcGIS10新功能之制作地图集
  2. 解读ASP.NET 5 MVC6系列(17):MVC中的其他新特性
  3. 【Android 异步操作】Handler 机制 ( Android 提供的 Handler 源码解析 | Handler 构造与消息分发 | MessageQueue 消息队列相关方法 )
  4. Computer:现代计算机操作系统的四大基本特性(并发/共享/虚拟/异步)
  5. 耦合式是什么意思_高内聚 ,低耦合 到底是什么意思?
  6. 100种不错的工具和资源
  7. [古诗]有关日本留学生的那些古诗
  8. snmp v3的安全配置 snmp认证与加密配置(53)
  9. mcd opc读取数据 西门子数控nx_西门子TIA+PLCSIM+MCD,构建自动化仿真系统
  10. 【开源】OSharp3.0框架解说系列(6.2):操作日志与数据日志
  11. Struts2表单验证的xml配置
  12. 线下广告投放方案_本地餐饮该怎样做好广告投放?传统广告投放的弊端和痛点...
  13. 【信号与系统】笔记合集,你确定不收藏吗?我已经收藏了
  14. 需求分析 - 01外卖配送系统
  15. virtio-scsi和virtio-blk的理解
  16. 完了,又火一个 。。。
  17. 新手小白开始学习verilog(学习方法有点歪门邪道的,大佬勿喷( ̄▽ ̄)“)
  18. 获取QQ邮箱的授权码
  19. dubbo之使用nacos作为注册中心
  20. 没有处理程序要使用以下任何注释:javax.persistence.PersistenceContext

热门文章

  1. c语言中fopen的作用,c语言fopen函数的用法
  2. 基于深度学习的高精度交警检测识别系统(PyTorch+Pyside6+YOLOv5模型)
  3. redis基础和原理全覆盖
  4. linux系统日志的查看和采集
  5. log4j-over-slf4j与slf4j-log4j12共存stack overflow异常分析
  6. 安信可ESP8266接入阿里生活飞燕平台国际版,实现亚马逊Alexa Echo音响语音控制;
  7. ICML2018论文研讨会记录
  8. 高斯滤波 java_Canny边缘检测java实现
  9. 蕾塞步进电机不动异常
  10. java实体类间的转换_java 实体类集合转换和实体类转换