jpg原理:读取原图片的像素点的rgb颜色值并保存到文件内,然后将原图进行翻倍放大,在放大的图上进行绘制,绘制一个像素的翻倍大小,一行一行的绘制,然后保存并删掉颜色文件
png原理:因为有部分png是透明的,所以以rgba颜色值进行保存并绘制,先生成颜色文件和模板图片,模板图片是8uy88767.png 这个模板图片是原图的翻倍大小,是临时的模板,然后生成完毕后再读取颜色文件,在模板图片上进行重组并生成最终的图片,也就是无损放大后的图片
别忘了留个赞
这个是将原图无损放大8倍的效果,jpg格式
这个是将原图无损放大8倍的效果,png格式
无损放大jpg源代码
#!/usr/bin/python # -*- coding:utf-8 -*- import cv2 from pil import image import time import shutil import os data = input('请输入要放大的图片名称(jpg文件名称必须使用数字或英文):') multiple = int(input('请输入要放大的图片的倍数(必须大于1):')) data_file = input('请输入要图片要保存的图片名称:') print('开始放大....') os.mkdir('data') # 新建 #读取图片 要放大的图片 src = cv2.imread(data) # 用来读取原图片的像素rgb颜色值 先读取图片文件 img = image.open(data) #获取图像大小 获取图像的大写xy也是颠倒过来的 y, x = src.shape[:2] # 临时装饰器 list_elements = [] for yy in range(y): # 获取图片的y轴有多少像素 也相当于长度 '''意思:循环读取图片的每一个像素点的rgb值 并以列表的形式存储起来''' if int(len(list_elements)) >= 2: # 每次循环完毕后要将列表的值恢复无 list_elements = [] for xx in range(x): # 获取图片的x轴有多少像素 也相当于宽度 # img.getpixel((a, aa)) 用来获取图片某位置的rgb像素值 提示:获取的值 对应 bgr 是rgb反过来的 list_elements = list_elements + [list(img.getpixel((xx, yy)))] # 读取某坐标的像素值并将元组为列表进行存储 name = open(f"data/{yy}", 'w') # 存储 name.write(str(list_elements)) # 将列表转为字符串保存 name.close() time.sleep(2) # 延迟一下 ,防止文件加载过慢读取错误 # 图像缩放 要将原图进行翻倍放大 然后在原图的基础上进行绘图 result = cv2.resize(src, (x*multiple,y*multiple)) for rgb_data_y in range(y): # 循环所有文件 y有多少像素 就有多少个rgb颜色文件 '''循环读取刚刚存储的rgb颜色文件 并循环进行绘制 以倍数进行绘图 确保无损放大''' name_ = eval(open(f'data/{rgb_data_y}', 'r', encoding='utf-8').read()) # 读取文件并转为列表 for rgb_data_x in range(len(name_)): # 获取 文件内有多少个子列表 ''' 因为通过getpixel 获取出来的颜色是反过来的 rgb 也就是 bgr 在颜色文件内的数值也是反过来的,所以在这里读取的时候要将其颠倒一下,反向转换一下 ''' _data = name_[rgb_data_x] _data.reverse() ''' 当前这个模块是核心模块 主要是用来读取并绘制出原图的倍数 原理: result[1,1] = [255,255,255] 填充 图片的第一个像素为白色 [255,255,255] 是rgb的白色颜色数值 result[0:2,0:4] = [255,255,255] 填充图片 x轴从0像素到2像素为白色 y轴从0像素到4像素为白色 ''' try: result[rgb_data_y*multiple:rgb_data_y*multiple+multiple,rgb_data_x*multiple:rgb_data_x*multiple+multiple] = _data except:pass # 写入保存图像 cv2.imwrite(data_file, result) print('完成....') try: shutil.rmtree("data") # 删除文件夹和文件 except:pass
无损放大png源代码
#!/usr/bin/python # -*- coding:utf-8 -*- import cv2 from pil import image import time import shutil import os data = input('请输入要放大的图片名称(png文件名称必须使用数字或英文):') multiple = int(input('请输入要放大的图片的倍数(必须大于1):')) data_file = input('请输入要图片要保存的图片名称:') print('开始放大....') os.mkdir('data') # 新建 #读取图片 要放大的图片 src = cv2.imread(data) # 用来读取原图片的像素rgb颜色值 先读取图片文件 img = image.open(data) #获取图像大小 获取图像的大写xy也是颠倒过来的 y, x = src.shape[:2] # 模板 # 图像缩放 要将原图进行翻倍放大 然后在原图的基础上进行绘图 result = cv2.resize(src, (x*multiple,y*multiple)) # 写入保存图像 - 模板图片不用管 cv2.imwrite('8uy88767.png', result) # 临时装饰器 list_elements = [] # 存储文件的个数 后期读取方便,不会错读取 number_documents = 0 for yy in range(y): # 获取图片的y轴有多少像素 也相当于长度 '''意思:循环读取图片的每一个像素点的rgba值 并以列表的形式存储起来''' if int(len(list_elements)) >= 2: # 每次循环完毕后要将列表的值恢复无 list_elements = [] for xx in range(x): # 获取图片的x轴有多少像素 也相当于宽度 # img.getpixel((a, aa)) 用来获取图片某位置的rgba像素值 list_elements = list_elements + [img.getpixel((xx, yy))]*multiple # 读取某坐标的像素值并将元组为列表进行存储 multiple是倍数 for a in range(multiple): # multiple是倍数 如果是2倍 则生成两个同样的颜色文件 在后期进行单行输出多次 确保以像素点进行放大 name = open(f"data/{number_documents}", 'w') # 存储 name.write(str(list_elements)) # 将列表转为字符串保存 name.close() number_documents = number_documents + 1 time.sleep(1) # 延迟一下 ,防止文件加载过慢读取错误 data_ = list() # 定义需要处理的数据列表 for a in range(number_documents): name = open(f"data/{a}", 'r').read() # 读取颜色文件 name = list(eval(name)) # 将颜色文件转换为列表 for aa in range(len(name)): # 循环读取列表的颜色值 data_.append(name[aa]) # 将颜色值保存到数据列表 # 打开写入模板图片 img_2 = image.open('8uy88767.png') # 转化为rgba rgba_img = img_2.convert("rgba") rgba_img.putdata(data_) # 写入图片 rgba_img.save(data_file, "png") # 保存图片 print('完成....') try: shutil.rmtree("data") # 删除文件夹和文件 except:pass try: os.remove("8uy88767.png") # 删除文件 except:pass
到此这篇关于python实现无损放大图片的示例代码的文章就介绍到这了,更多相关python无损放大图片内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!