python实现书法碑帖图片分割

本文实例为大家分享了python实现书法碑帖图片分割的具体代码,供大家参考,具体内容如下

一、功能实现效果

1、选择要分割的碑帖图片

2、选择碑帖图像分割的行与列,本例的行为:5,列为:4。如何点击“确定行列”

3、输入对于碑帖的内容,点击“确定分割”按钮。

4、在输出文件夹生成了单字版图片,并对应内容命名。方便集字、创作与学习。

二、Python代码实现

1、getimgdir.py

import wx
import os
from PIL import Image
import numpy as np
#import wx.grid
#import row_col
#row_col
#######################################################################################
app = wx.App() #wx.App()行创建了一个应用程序对象。每个 wx 程序都需要一个 .App() 对象
frame = wx.Frame(None, -1, '请选择待分割的图片文件') #wx.Frame()方法返回一个可以包含小部件的新窗口
frame.SetSize(0,0,600,300) #函数设置位置和大小(x(左),y(顶部),宽度,高度)
openFileDialog = wx.FileDialog(frame, "Open", "", "",
                   "all files (*.*)|*.*",
                    wx.FD_OPEN | wx.FD_FILE_MUST_EXIST)

openFileDialog.ShowModal() #显示窗口
src = openFileDialog.GetPath() #返回文件的完整路径(如果选择了一个)
np.savez('dir.npz', k_a=src)
openFileDialog.Destroy()

2、row_col.py

import wx
import numpy as np
import sys
import time
import os
class MyFrame(wx.Frame):
  ClickNum = 0
  def __init__(self):   #__init__(self) 是类的初始化方法,也称构造方法,是一种特殊的魔法方法。__init__(self)在实例化后,会自动调用,而不用手动调用,所以一般把属性设置在_init__()里。
    super().__init__(parent=None,title="图像分割行数与列数",size=(500,730)) # 初始化窗口信息
    panel = wx.Panel(self)  #框架的父窗口。对于顶级窗口,这个值是None 。#创建面板
    #模块1 选择签约主体
    self.Center()
    text1 = wx.StaticText(parent=panel,id=-1,pos=(10,7),label="图像分割行数:")
    list1 = ["1","2","3","4","5","6","7","8","9","10"]
    self.combobox1=wx.ComboBox(parent=panel,id=-1,pos=(100,5),value="5",choices=list1)#wx.ComboBox 默认它的文本框是可以修改的

    text2 = wx.StaticText(parent=panel, id=-1, pos=(250, 7), label="图像分割列数:")
    list2 = ["1","2","3","4","5","6","7","8","9","10"]
    self.combobox2 = wx.ComboBox(parent=panel, id=-1, pos=(350, 5), value="4",choices=list2) # wx.ComboBox 默认它的文本框是可以修改的

    datadir = np.load('dir.npz')
    imgdir = str(datadir['k_a'])
    copybookimg = wx.Bitmap(imgdir, wx.BITMAP_TYPE_ANY)
    img = wx.Image(imgdir)
    w1,h1 = copybookimg.GetSize()
    if h1>400:
     neww1 = (400*w1)/h1
     newh1 = 400
     img2=img.Scale(int(neww1),newh1)
     img2=wx.Bitmap(img2)
     self.image = wx.StaticBitmap(panel, -1, img2,pos=(10, 90))

    st1 = wx.StaticText(panel, -1, "字帖内容:", pos=(10, 505))

    self.txt1 = wx.TextCtrl(panel, -1, pos=(60, 530), size=(int(13.26*1+23.5), 140), style=wx.TE_MULTILINE)

    #提交模块
    self.button = wx.Button(panel, -1, "确定行列", pos=(200, 40), size=(60, 30)) # 在面板上添加控件
    self.Bind(wx.EVT_BUTTON, self.OnClick, self.button) # 将回调函数与按键事件绑定

  def OnClick(self, event): # 回调函数事件
      self.button.SetLabel("提交成功") # 设置
      self.ClickNum += 1
      if self.ClickNum % 2 == 1: # 根据按下次数判断
        self.button.SetLabel("已经提交") # 修改按键的标签
        a = self.combobox1.GetValue()
        b = self.combobox2.GetValue()
        np.savez('abc.npz', k_a=a, k_b=b)
        #time.sleep(0.1)
        self.Close()

class App(wx.App):
  def OnInit(self):
    frame = MyFrame()
    frame.Show()
    return True
app = App()
app.MainLoop()
#time.sleep(2)
#sys.exit(0)

3、row_col_show.py

import wx
import numpy as np
import threading
import time
from PIL import Image,ImageDraw
def draw_line(dir,a,b):
 im = Image.open(dir)
 draw = ImageDraw.Draw(im) #实例化一个对象
 #a #行 图像的宽:im.size[0]
 #b #列 图像的高:im.size[1]
 a=int(a)
 b=int(b)
 c=im.size[0]
 d=im.size[1]
 for i in range(a):
  draw.line((0, d*(i+1)/a) + (c,d*(i+1)/a), fill=128, width=5) #线的起点和终点,线宽
 for j in range(b):
  draw.line((c*(j+1)/b,0) + (c*(j+1)/b,d), fill=128, width=6)
 return(im.save("00.jpeg"))

class MyFrame(wx.Frame):
  ClickNum = 0

  def __init__(
      self): # __init__(self) 是类的初始化方法,也称构造方法,是一种特殊的魔法方法。__init__(self)在实例化后,会自动调用,而不用手动调用,所以一般把属性设置在_init__()里。
    super().__init__(parent=None, title="图像分割行数与列数", size=(500, 730)) # 初始化窗口信息
    panel = wx.Panel(self) # 框架的父窗口。对于顶级窗口,这个值是None 。#创建面板
    # 模块1 选择签约主体
    self.Center()
    data_a = np.load('abc.npz')
    split_row = int(data_a['k_a']) # 读取行数
    split_col = int(data_a['k_b']) # 读取列数

    text1 = wx.StaticText(parent=panel, id=-1, pos=(10, 7), label="图像分割行数:")
    list1 = ["1", "2", "3", "4", "5", "6", "7", "8", "9", "10"]
    self.combobox1 = wx.ComboBox(parent=panel, id=-1, pos=(100, 5), value=str(split_row),
                   choices=list1) # wx.ComboBox 默认它的文本框是可以修改的

    text2 = wx.StaticText(parent=panel, id=-1, pos=(250, 7), label="图像分割列数:")
    list2 = ["1", "2", "3", "4", "5", "6", "7", "8", "9", "10"]
    self.combobox2 = wx.ComboBox(parent=panel, id=-1, pos=(350, 5), value=str(split_col),
                   choices=list2) # wx.ComboBox 默认它的文本框是可以修改的
    datadir = np.load('dir.npz')
    imgdir = str(datadir['k_a'])
    copybookimg = wx.Bitmap(imgdir, wx.BITMAP_TYPE_ANY)
    #img = wx.Image(imgdir)
    draw_line(imgdir, str(split_row), str(split_col))
    img3 = wx.Image("00.jpeg")
    w1, h1 = copybookimg.GetSize()
    if h1 > 400:
      neww1 = (400 * w1) / h1
      newh1 = 400
      img2 = img3.Scale(neww1, newh1)
      img2 = wx.Bitmap(img2)
      self.image = wx.StaticBitmap(panel, -1, img2, pos=(10, 90))
    st1 = wx.StaticText(panel, -1, "字帖内容:", pos=(10, 505))
    for i in range(split_col):
      wx.StaticText(panel, -1, "第"+str(i+1)+"列:", pos=(10, 530+20*i))

    self.txt1 = wx.TextCtrl(panel, -1, pos=(60, 530), size=(13.26 * split_row + 23.5, split_col *20), style=wx.TE_MULTILINE)

    # 提交模块
    self.button = wx.Button(panel, -1, "确定分割", pos=(400, 650), size=(60, 30)) # 在面板上添加控件
    self.Bind(wx.EVT_BUTTON, self.OnClick, self.button) # 将回调函数与按键事件绑定

  def OnClick(self, event): # 回调函数事件
    self.button.SetLabel("提交成功") # 设置
    self.ClickNum += 1
    if self.ClickNum % 2 == 1: # 根据按下次数判断
      self.button.SetLabel("已经提交") # 修改按键的标签
      a = self.combobox1.GetValue()
      b = self.combobox2.GetValue()
      c = self.txt1.GetValue()
      np.savez('abc.npz', k_a=a, k_b=b, k_c=c) #k_c = c碑帖内容保存npz文件
      self.Close()
class App(wx.App):
  def OnInit(self):
    frame = MyFrame()
    frame.Show()
    return True
app = App()
app.MainLoop()

4、split_copybook.py

# -*- coding: utf-8 -*-

import wx
import os
from PIL import Image
import numpy as np
#import wx.grid
#import row_col
#row_col
#######################################################################################
data_a = np.load('dir.npz')
src=str(data_a['k_a'])#地址

def splitimage(src, rownum, colnum, dstpath): #分割图像,(输入图片路径,分割行数,分割列数,输出图片路径)

  img = Image.open(src)
  src=src.replace('jpg','jpeg')

  print(src)
  #os.getcwd()
  w, h = img.size
  if rownum <= h and colnum <= w:
    print('原碑帖图片信息: %sx%s, %s, %s' % (w, h, img.format, img.mode))
    print('

5、main.py

import os
os.system("python ./getimgdir.py")
os.system("python ./row_col.py")
os.system("python ./row_col_show.py")
os.system("python ./split_copybook.py")
os.unlink('00.jpeg')
os.unlink('abc.npz')
os.unlink('dir.npz')

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Python切割图片成九宫格的示例代码

    这篇文字讲述如何使用Python把一张完整的大图切割成9份小图片,制作朋友圈九宫格图文分享. 原图如下: 我们想要利用这张图制作高逼格的九宫格朋友圈分享. 达到类似于这样的效果: 实现原理非常简单,那就是利用PIL库对原图不断画小区域然后切下来存储成新的小图片. 假设每一个格子的宽和高分别是w.h,那么第row行(从0开始计数),第col列(从0开始计数)的格子左上角坐标和右下角坐标分别是(col * w, row * h),(col * w + w, r * h + h). code snip

  • python3 实现验证码图片切割的方法

    切割前图片 切割后四个图片 代码 #coding:utf8 import os from PIL import Image,ImageDraw,ImageFile import numpy import pytesseract import cv2 import imagehash import collections class pictureIdenti: #rownum:切割行数:colnum:切割列数:dstpath:图片文件路径:img_name:要切割的图片文件 def spliti

  • python opencv实现图片旋转矩形分割

    有时候需要对有角度的矩形框内图像从原图片中分割出来.这里的程序思想是,先将图片进行矩形角度的旋转,使有角度的矩形处于水平状态后,根据原来坐标分割图片. 参考:python opencv实现旋转矩形框裁减功能 修改原来的程序: 1.旋转函数的输入仅为矩形的四点坐标 2.角度由公式计算出来 3.矩形四点pt1,pt2,pt3,pt4由txt文件读入 4.在旋转程序中还处理了顺时针和逆时针及出现矩形框翻转的问题. 代码: # -*- coding:utf-8 -*- import cv2 from m

  • Python+opencv 实现图片文字的分割的方法示例

    实现步骤: 1.通过水平投影对图形进行水平分割,获取每一行的图像: 2.通过垂直投影对分割的每一行图像进行垂直分割,最终确定每一个字符的坐标位置,分割出每一个字符: 先简单介绍一下投影法:分别在水平和垂直方向对预处理(二值化)的图像某一种像素进行统计,对于二值化图像非黑即白,我们通过对其中的白点或者黑点进行统计,根据统计结果就可以判断出每一行的上下边界以及每一列的左右边界,从而实现分割的目的. 下面通过Python+opencv来实现该功能 首先来实现水平投影: import cv2 impor

  • python实现图片九宫格分割

    大家都知道在微信朋友圈或者微博以及QQ动态中,有很多"强迫症患者"发图片都爱发9张,而有些图是一张图片分成的九宫图,对于这种操作,大家知道是怎么做到的吗? 本文就是用Python做的一个九宫格图片生成器,是一个打包好的exe文件,用户无需部署安装Python的开发环境,在本地就可以运行此程序,以此快速生成九宫格图片. 下面是程序的所有代码,这是一个Python GUI程序,代码不多,也很容易理解: # -*- coding: UTF-8 -*- # 将一张图片分成九张,九宫格 impo

  • python切割图片的示例

    这个小程序可以自己设定行数和列数进行图片切割 import os from PIL import Image def splitimage(src, rownum, colnum, dstpath): img = Image.open(src) w, h = img.size if rownum <= h and colnum <= w: print('Original image info: %sx%s, %s, %s' % (w, h, img.format, img.mode)) pri

  • python实现对任意大小图片均匀切割的示例

    改代码是在windows 系统下 打开路径和保存路径换成自己的就可以啦~ import numpy as np import matplotlib import os def img_seg(dir): files = os.listdir(dir) for file in files: a, b = os.path.splitext(file) img = Image.open(os.path.join(dir + "\\" + file)) hight, width = img.s

  • python3 实现对图片进行局部切割的方法

    先拿个图片举例子,比如说截取途中方框内的图片: # 导入相关的库 from PIL import Image # 打开一张图 img = Image.open('test.jpg') # 图片尺寸 img_size = img.size h = img_size[1] # 图片高度 w = img_size[0] # 图片宽度 x = 0.25 * w y = 0.16 * h w = 0.5 * w h = 0.2 * h # 开始截取 region = img.crop((x, y, x +

  • python实现图片中文字分割效果

    本文实例为大家分享了python实现图片中文字分割的具体代码,供大家参考,具体内容如下 1.原始图片(包含数字): 结果图: 2.原始图片(包含文字): 结果图: 3.代码如下: import cv2 import numpy as np path = 'test.jpg' root = 'output\\' # 图像resize dsize = 36 img = cv2.imread(path) data = np.array(img) height = data.shape[0] width

  • python opencv将表格图片按照表格框线分割和识别

    如下小程序为使用python+opencv将表格图片,按照表格进行分割,并识别分割后的子图片中的文字,希望对需要的小伙伴有一些些帮助.具体的实现见如下代码. # -*- coding: utf-8 -*- """ Created on Tue May 28 19:23:19 2019 将图片按照表格框线交叉点分割成子图片(传入图片路径) @author: hx """ import cv2 import numpy as np import py

随机推荐