首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么我的imshow不同于imwrite

imshow和imwrite是OpenCV库中用于图像显示和图像保存的函数。

imshow函数用于在窗口中显示图像,而imwrite函数用于将图像保存为文件。它们之间的主要区别在于:

  1. 显示方式:imshow函数会创建一个窗口并将图像显示在窗口中,而imwrite函数则将图像保存为文件,不进行显示。
  2. 显示格式:imshow函数可以显示多种图像格式,包括常见的BGR、RGB、灰度图等,而imwrite函数只能保存为特定的图像格式,如JPEG、PNG等。
  3. 参数设置:imshow函数可以通过参数调整图像的显示效果,如调整亮度、对比度等,而imwrite函数只需指定保存路径和文件格式即可。

所以,如果你发现imshow和imwrite的结果不同,可能是以下原因导致的:

  1. 图像格式不同:imshow函数可以显示多种图像格式,而imwrite函数只能保存为特定的图像格式。如果你的图像格式不是imwrite函数支持的格式,保存后的图像可能与imshow显示的结果不同。
  2. 参数设置不同:imshow函数可以通过参数调整图像的显示效果,而imwrite函数不会对图像进行任何处理。如果你在imshow函数中使用了参数调整图像的显示效果,保存后的图像可能与imshow显示的结果不同。

综上所述,imshow和imwrite是用于图像显示和保存的函数,它们之间的差异主要在于显示方式、显示格式和参数设置。如果你发现它们的结果不同,可能是因为图像格式不同或参数设置不同导致的。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

OpenCV图像读取(imread) 显示(imshow) 保存(imwrite)冷知识点

OpenCV图像读取(imread) 显示(imshow) 保存(imwrite)冷知识点,虽然很基础,但也有用。...tif格式图片,它本来是2张图片组成,那么就可以一次性读进来,然后对vector进行处理,避免对图片路径进行字符串格式化。...二、显示图像:namedWindow() 和 imshow() 1. imshow()函数默认显示窗口模式是WINDOW_AUTOSIZE,它好处是可以根据图像大小自动调整大小显示,...三、保存图像:imwrite() 1. 大家比较熟悉应该是用imwrite()来保存单张图片,我们也可以用它来一次性保存多张图片到一个文件中,看函数说明: ?...imgs.at(0)); imshow("2", imgs.at(1)); waitKey(0); .tif这个格式如果你用过halcon就会经常看到它身影, 为什么老是用它?

1.8K10

番外篇: 无损保存和Matplotlib

可以用画图工具新建一副100×100图像,分别保存成这三种格式来验证: 高质量保存 用cv2.imwrite()保存图片时,可以传入第三个参数(请参考接口文档),用于控制保存质量: cv2.IMWRITE_JPEG_QUALITY.../1024 ≈ 359 KB) jpg/png本身就有压缩,所以就算是100%质量保存,体积也比bmp小很多 jpg容量优势很明显,这也是它为什么如此流行原因 思考:为什么原图49.7KB,保存成...这是个很有趣问题,很多童鞋都问过。...plt.subplot(121),plt.imshow(img) # 显示正确图 plt.subplot(122) plt.xticks([]), plt.yticks([]) # 隐藏x和y轴...plt.imshow(img2) plt.show()Copy to clipboardErrorCopied img[:,:,0]表示图片蓝色通道,img[:,:,::-1]就表示BGR翻转,变成

1.5K30
  • 为什么BERT不行?

    当然了,bad case分析这块也聊了很多,多分析能发现其中端倪,知道模型需要什么,该怎么处理,再放一遍在这里,希望能好好阅读。...训练层面的分析 BERT训练其实挺多讲究,这里实验效果要保证对参数有一定要求,所以大家要多去观察训练过程暴露问题,训练过程其实就是要观测loss变化、验证集效果等问题,放置没学到、学飘了之类问题...类似的思路其实在这两篇文章里其实都有谈过: 心法利器[44] | 样本不均衡之我见 所以,很多时候你需要可能是更多地挖掘数据,从日志,从更多渠道去找,这个可能比增强本身要好。...这里背后逻辑可以参考这篇文章: 心法利器[45] | 模型需要信息提供够了吗 训练问题 针对训练问题,其实也就是一个经验问题了,多弄其实问题就会小很多,大家可以多去看各个论文使用超参,一般调差不多基本都不会有的...而文章本身输出并非是按照这个思路走,而是从一些大家经常问点深入来讨论,希望能从角度和风格来思考和回答问题。

    1.2K20

    python cv.imread_为什么cv2里没有imread

    为什么使用Python-OpenCV 虽然python 很强大,而且也有自己图像处理库PIL,但是相对于OpenCV 来讲,它还是弱小很多。...2、显示图像cv2.imshow() 使用函数cv2.imshow() 显示图像。窗口会自动调整为图像大小。第一个参数是窗口名字,其次才是我们图像。...cv2.imshow(‘image’,img) cv2.waitKey(0) 3、保存图像cv2.imwrite() cv2.imwrite('lena.png',img) ===========...=============== 使用cv2.imread(),cv2.imshow(),cv2.imwrite()读取、显示和保存图像 一、读入图像 使用函数cv2.imread(filepath,flags...(wname,img)显示图像,第一个参数是显示图像窗口名字,第二个参数是要显示图像(imread读入图像),窗口大小自动调整为图片大小 cv2.imshow(‘image’,img) cv2.

    2.5K20

    EmguCV学习——简单使用

    关于EmguCV就不多说了,是对应于OpenCV一套net库。 公司是视觉方面的业务,又不会c++(好想会啊,正在学习中)。...由于各种需求,自己觉得对c++不是特别感冒,所以选用了net下opencv封装EmguCV。python也有对应opencv库。无奈python还处于入门阶段。...不废话,先说Emgucv配置,是看园子里博客配置,附上链接:  http://www.cnblogs.com/bomo/archive/2013/03/28/2986113.html 下面先演示一下简单显示图片及视频...) 14 cv2.imshow("img",img) 15 #保存图片 质量为5 和 100 16 cv2.imwrite("./1.jpg",img,[int(cv2.IMWRITE_JPEG_QUALITY.../img/%d.jpg" % i,frame) 20 i = i + 1 21 success, frame = videoCapture.read() 以上代码都是自己网上找demo

    2.4K10

    为什么要写自己框架?

    其实说白了框架就是使用别人造好轮子。在软件开发里面就是command+C/command+V。 先自我介绍一下,是一名信管专业大学生,从专业可以看出就是以后大家嘴里程序员。...曾几何时,觉得很兴奋,在如此短时间内就可以做到这样高度,让十分开心。开发出内容也完全符合校内应用需求。变成了一个别人眼中“大师”。 但事情并没有往想象地方发展。...框架用时间久了之后就发现了一个问题:真的有学习过吗?内容真的有用嘛,这些框架内东西能对今后有帮助吗,当然,这种想法不是一天形成,还有一个小故事。...但当有一天在讲授开发经验时候,当我当着大家面真的静下心来写需要展示一个类时候,以前用了这么多框架,发现在这么多人面前已经几乎写不出来一个正确类了!!...于是又开始新一轮学习,看大量书籍,有一天重新打开Yii框架在当时看起来很难理解代码时候发现:居然有点明白它工作原理,知道整体架构了!

    1.3K20

    为什么Redis这么“慢”?

    如果你服务请求量并不大,但 Redis 实例 CPU 使用率很高,很有可能是使用了复杂度高命令导致。...同样,当删除这个 Key 数据时,释放内存也会耗时比较久。 你需要检查你业务代码,是否存在写入大 Key 情况,需要评估写入数据量大小,业务层应该避免一个 Key 存入过大数据量。...内存中数据写入磁盘,这个会加重磁盘 IO 负担,操作磁盘成本要比操作内存代价大得多。...下面就针对这两块,分享一下认为比较合理 Redis 使用和运维方法,不一定最全面,也可能与你使用 Redis 方法不同,但以下这些方法都是在踩坑之后总结实际经验,供你参考。...总结 以上就是在使用 Redis 和开发 Redis 相关中间件时,总结出来 Redis 推荐实践方法,以上提出这些方面,都或多或少在实际使用中遇到过。

    3.6K10

    不废话,看我20行代码搞定色块提取与定位…….

    问题来由 这个问题是谁问我已经不记得了,刚开始时候他发了这张图像给我,让给他看一下,当时告诉他转换一下色彩空间提取就好啦,后来记得他在微信上有问了一次,今天整理文件看到这张图又想起了,感觉他问了好几次都没回复挺不意思...先看看他发图像文件吧 ? 在来说说他需求: 找到途中全部青色区域,检测出来,绘制中心点!他用霍夫变换,结果直接翻车了,原因其实很理解,这个图有很多梯度干扰,噪声干扰,用了肯定翻车!...然后选择5x5开操作,完成之后得到 ? 使用OpenCV轮廓发现,对轮廓拟合圆,求圆心坐标得到输出结果如下: ? 怎么样,效果好吗?...("binary", mask); 22 imwrite("D:/binary.png", mask); 23 24 // 轮廓发现 25 vector>...("result", image); 41 imwrite("D:/result.png", image); 42 waitKey(0); 43 return 0; 44} 45

    1.2K20
    领券