OpenCVSharp 笔记21 图像旋转

        #region 图像旋转
        static void Main(string[] args)
        {
            //Mat src = new Mat("lenna.png", ImreadModes.AnyColor | ImreadModes.AnyDepth);
            //Cv2.ImShow("lenna.png", src);

            //Mat M = Cv2.GetRotationMatrix2D(new Point2f(src.Width/2,src.Width/2),30,1.0);
            //Mat output = new Mat();
            //Cv2.WarpAffine(src, output, M, src.Size(),InterpolationFlags.Linear,BorderTypes.Constant,new Scalar (255,255,0));
            //Cv2.ImShow("output", output);
            //Cv2.WaitKey();

            Mat src = new Mat("lenna.png", ImreadModes.AnyColor | ImreadModes.AnyDepth);
            Cv2.ImShow("lenna.png", src);
            Mat M = Cv2.GetRotationMatrix2D(new Point2f(src.Width / 2, src.Height / 2), 30, 1.0);
            Mat output = new Mat();

            double cos = M.Get<double>(0, 0);
            double sin = M.Get<double>(0, 1);
            int nw = (int)(cos * src.Width + sin * src.Height);
            int nh = (int)(sin * src.Width + cos * src.Height);

            M.Set<double>(0, 2, M.Get<double>(0, 2) + (nw/2 - src.Width/2));
            M.Set<double>(1, 2, M.Get<double>(1, 2) + (nh / 2 - src.Height / 2));

            Cv2.WarpAffine(src, output, M, new Size(nw, nh), InterpolationFlags.Linear, BorderTypes.Constant, new Scalar(255, 255, 0));
            Cv2.ImShow("output", output);
            Cv2.WaitKey();
        }
        #endregion

在这里插入图片描述

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值