iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >python实现求纯色彩图像的边框的方法
  • 367
分享到

python实现求纯色彩图像的边框的方法

2023-06-14 10:06:26 367人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

这篇文章主要讲解了“python实现求纯色彩图像的边框的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python实现求纯色彩图像的边框的方法”吧!python是什么意思Python是一

这篇文章主要讲解了“python实现求纯色彩图像的边框的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python实现求纯色彩图像的边框的方法”吧!

python是什么意思

Python是一种跨平台的、具有解释性、编译性、互动性和面向对象的脚本语言,其最初的设计是用于编写自动化脚本,随着版本的不断更新和新功能的添加,常用于用于开发独立的项目和大型项目。

先上效果图,这里显示有点色差, 实际数值是纯色的, 而不是混色的.

python实现求纯色彩图像的边框的方法

放大局部细节看是这样的

python实现求纯色彩图像的边框的方法

原图是下面这样的

python实现求纯色彩图像的边框的方法

这个算法最大的特点是保留原始像素的数值, 而不是把边框统一变成白色.
实现的算法也超级简单. 就是有点慢. 考虑到我这个应用场景对性能要求不高, 比人快就行. 人工是它的几百倍. 所以也就无所谓啦.
测试结果一张1080*1920的图用时3秒, 如果换成C语言估计0.5秒左右.

算法原理, 每次4个田子形像素逐行扫描. 发现4个像素不一致的就输出到结果图上. 否则就是输出0.

代码如下.

## demo.py# 识别单张图片#import argparseimport os import numpy as npimport timefrom modeling.deeplab import *from dataloaders import custom_transfORMs as trfrom PIL import Imagefrom torchvision import transformsfrom dataloaders.utils import  *from torchvision.utils import make_grid, save_image,to_imageimport matplotlibmatplotlib.use('TkAgg')import matplotlib.pyplot as pltdef main():    im = Image.open("test_border.png")    npimg = np.array(im) # 这个图片是1维的索引图.     # chwimg = npimg.transpose(2,0,1) # HWC 变成 CHW 格式的矩阵    print(npimg.shape)    h,w,c = npimg.shape    src = np.sum(npimg,axis=2) # 这里测试用, 先把3通道的合成了一个通道的, 实际使用的时候也是1通道的.    print(src.shape)    borderimg = np.zeros(src.shape) #默认都输出了0 后面就不用输出0了.    # 修补bug, 解决边框线会丢失的问题.    borderimg[0,:]=src[0,:]    borderimg[:,0]=src[:,0]    borderimg[-1,:]=src[-1,:]    borderimg[:,-1]=src[:,-1]       t1= time.time()    for x in range(0,h-1,1):         for y in range(0,w-1,1):            # point = src[x,y]            # if(point>0):                # print(point)            if not (src[x,y] == src[x+1,y] == src[x,y+1] == src[x+1,y+1]): # 发现4个像素不一致的就输出到结果图上.                borderimg[x,y] = src[x,y]                borderimg[x+1,y] = src[x+1,y]                borderimg[x,y+1] = src[x,y+1]                borderimg[x+1,y+1] = src[x+1,y+1]    t2= time.time()    print("耗时",t2-t1)    plt.figure()    plt.title('display')     plt.imshow(src)     plt.show( )    plt.imshow(borderimg)     plt.show( )    print("start test get image border ...")if __name__ == "__main__":    main()else:    main()

感谢各位的阅读,以上就是“python实现求纯色彩图像的边框的方法”的内容了,经过本文的学习后,相信大家对python实现求纯色彩图像的边框的方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: python实现求纯色彩图像的边框的方法

本文链接: https://www.lsjlt.com/news/270251.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作