码迷,mamicode.com
首页 > 编程语言 > 详细

用python给女朋友照片加上个性相框,学会等着她夸你!

时间:2020-09-09 19:11:07      阅读:60      评论:0      收藏:0      [点我收藏+]

标签:堆叠   source   tween   array   ipv6   float   byte   sha   turn   

讲解下如何给女朋友照片加上个性相框,学会让她夸你。

素材1
相框

技术图片

你的女朋友图

技术图片

代码

import cv2
import numpy as np
def get_four_points(im):
    data = {}
    data[‘im‘] = im.copy()
    data[‘points‘] = []
    cv2.namedWindow("Image", 0)
    cv2.imshow(‘Image‘,im)
    #请注意你标记点的数据,是顺时针,需要与pst_src 方向一致
    cv2.setMouseCallback("Image",mouse_handler,data)
    cv2.waitKey(0)
    #竖直方向堆叠起来;
    points = np.vstack(data[‘points‘]).astype(float)
    return points
#---第4步:主函数---
def main():
    #美女照片读取,注意路径
    img_src = cv2.imread("meinv.jpg")
    size = img_src.shape
    # 取得四个坐标
    ##需要注意一点,坐标 Pick 点的顺序须与记录替换图像顶点顺序一致,否则转换图会有偏差
    pst_src = np.array(
        [
            [0,0],[size[1]-1,0],
            [size[1]-1,size[0]-1],
            [0,size[0]-1]
         ],dtype=float
    )
    #大图:相框,注意路径
    img_dst = cv2.imread("xiangkuang.jpg")
    print("点击bllboard的四个角,然后回车")#获取四个点
    four_point  = get_four_points(img_dst)
    #Calculate  Homography between  source and destination points
    #计算源点和目标点之间的单应性
    h,status = cv2.findHomography(pst_src,four_point)
    #透视变换(单应性)
    im_temp = cv2.warpPerspective(img_src,h,(img_dst.shape[1],img_dst.shape[0]))
    cv2.fillConvexPoly(img_dst,four_point.astype(int),0,16)
    #照片叠加
    img_dst = img_dst + im_temp
    cv2.namedWindow("Image", 0)
    cv2.imshow("Image",img_dst)
    cv2.imwrite(‘Image.png‘,img_dst)#照片保存
    cv2.waitKey(0)

#---第5步:调用main函数---
if __name__ ==‘__main__‘:
    main()

效果展示
描绘啦四个点后,点击enter 就可以啦

技术图片

得到的图

技术图片


当然也可以随意描点

技术图片

哈哈哈哈  非常简单  有没有  获取源代码打包工具加群:1136192749

 

用python给女朋友照片加上个性相框,学会等着她夸你!

标签:堆叠   source   tween   array   ipv6   float   byte   sha   turn   

原文地址:https://www.cnblogs.com/A3535/p/13582026.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!