本文实例为大家分享了python opencv旋转图像的具体代码,保持图像不被裁减,供大家参考,具体内容如下
# -*- coding:gb2312 -*-
import cv2
from math import *
import numpy as np
img = 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)
效果图:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
继续阅读与本文标签相同的文章
-
揭秘互联网之光博览会“网络安全”专题展区
2026-05-15栏目: 教程
-
“捅破”自动驾驶量产神话,Arm从幕后走到台前“GGAI视角”
2026-05-15栏目: 教程
-
综合续航里程达520km,试驾小鹏G3
2026-05-15栏目: 教程
-
谷歌Pixel 4闭眼、睡着都能解锁?
2026-05-15栏目: 教程
-
搭载L2自动驾驶,起售价7.58万,名爵ZS动力配置全面升级
2026-05-15栏目: 教程
