本文实例为大家分享了python opencv旋转图像的具体代码,保持图像不被裁减,供大家参考,具体内容如下
# -*- coding:gb2312 -*-import cv2from math import *import numpy as npimg = cv2.imread("3-2.jpg")height,width=img.shape[:2]degree=45#旋转后的尺寸heightNew=int(width*fabs(sin(radians(degree)))+height*fabs(cos(radians(degree))))widthNew=int(height*fabs(sin(radians(degree)))+width*fabs(cos(radians(degree))))matRotation=cv2.getRotationMatrix2D((width/2,height/2),degree,1)matRotation[0,2] +=(widthNew-width)/2 #重点在这步,目前不懂为什么加这步matRotation[1,2] +=(heightNew-height)/2 #重点在这步imgRotation=cv2.warpAffine(img,matRotation,(widthNew,heightNew),borderValue=(255,255,255))cv2.imshow("img",img)cv2.imshow("imgRotation",imgRotation)cv2.waitKey(0)
效果图:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林站长站。
新闻热点
疑难解答