旋转图片两种方法
短信预约 -IT技能 免费直播动态提醒
这两种方法在旋转图像时,可能会产生一些不同的效果:
rotate_image_new()旋转后的图像完全包含旋转前的内容,并且填充边界尽可能小
rotate_image() 保持原始图像的大小,并根据填充选项决定是否填充边界为白色。如果 if_fill_white 参数为 True,则填充边界为白色;否则,边界将保持原始图像的值。这种方法可以更快速地旋转图像,但可能会导致旋转后的图像包含额外的空白区域或丢失部分图像信息。
def rotate_image_new(image, degree): ''' 旋转图片角度 ''' from math import * # dividing height and width by 2 to get the center of the image height, width = image.shape[:2] 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(image, matRotation, (widthNew, heightNew), borderValue=(255, 255, 255)) return imgRotationdef rotate_image( image, angle,if_fill_white = False): ''' 顺时针旋转 ''' # dividing height and width by 2 to get the center of the image height, width = image.shape[:2] # get the center coordinates of the image to create the 2D rotation matrix center = (width / 2, height / 2) # using cv2.getRotationMatrix2D() to get the rotation matrix rotate_matrix = cv2.getRotationMatrix2D(center=center, angle=angle, scale=1) # rotate the image using cv2.warpAffine if not if_fill_white: rotated_image = cv2.warpAffine(class="lazy" data-src=image, M=rotate_matrix, dsize=(width, height) ) else: color = (255, 255) if len(image.shape)==2 else (255, 255,255) rotated_image = cv2.warpAffine(class="lazy" data-src=image, M=rotate_matrix, dsize=(width, height), borderValue=color) return rotated_image
来源地址:https://blog.csdn.net/weixin_38235865/article/details/132560980
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341