Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/326.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/user-interface/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python Tkinter。数据点的最佳拟合椭圆_Python_User Interface_Tkinter_Bmp - Fatal编程技术网

Python Tkinter。数据点的最佳拟合椭圆

Python Tkinter。数据点的最佳拟合椭圆,python,user-interface,tkinter,bmp,Python,User Interface,Tkinter,Bmp,我正在使用Tkinter开发Python GUI。我试图将BMP图像中的四个指定点位置保存到变量中,并创建一个或多或少通过保存点的最佳拟合椭圆。我仍然是一个初学者,使用Tkinter和GUI,所以请忍受我 到目前为止,代码能够标记这些点并打印出其位置/坐标。我应该在这种情况下使用matplotlib吗?我也能用那个w/tkinter吗 这是我的密码: from tkinter import * from PIL import Image, ImageTk class Window(Frame)

我正在使用Tkinter开发Python GUI。我试图将BMP图像中的四个指定点位置保存到变量中,并创建一个或多或少通过保存点的最佳拟合椭圆。我仍然是一个初学者,使用Tkinter和GUI,所以请忍受我

到目前为止,代码能够标记这些点并打印出其位置/坐标。我应该在这种情况下使用matplotlib吗?我也能用那个w/tkinter吗

这是我的密码:

from tkinter import *
from PIL import Image, ImageTk

class Window(Frame):

    def __init__(self, master=None):
        Frame.__init__(self, master)

        self.master = master
        self.pos = []
        self.master.title("GUI")
        self.pack(fill=BOTH, expand=1)

        self.counter = 0

        menu = Menu(self.master)
        self.master.config(menu=menu)

        file = Menu(menu)
        file.add_command(label="Exit", command=self.client_exit)
        menu.add_cascade(label="File", menu=file)
        analyze = Menu(menu)

        analyze.add_command(label="Region of 
        Interest",command=self.regionOfInterest)
        analyze.add_command(label="Erase", command=self.erasePoints)

        menu.add_cascade(label="Analyze", menu=analyze)
        load = Image.open("ap41.ddr.brf.sdat.bmp")
        render = ImageTk.PhotoImage(load)

        img = Label(self, image=render)
        img.image = render
        img.place(x=0, y=0)

    def regionOfInterest(self):
        root.config(cursor="plus")
        canvas.bind("<Button-1>", self.imgClick)

    def erasePoints(self):
        self.pos = []

    def client_exit(self):
        exit()

    def imgClick(self, event):

        if self.counter < 4:
            x = canvas.canvasx(event.x)
            y = canvas.canvasy(event.y)
            self.pos.append((x, y))
            print(self.pos)
            canvas.create_line(x - 5, y, x + 5, y, fill="red", 
tags="crosshair")
            canvas.create_line(x, y - 5, x, y + 5, fill="red", 
tags="crosshair")
            self.counter += 1
        else:
            canvas.unbind("<Button 1>")
            root.config(cursor="arrow")
            self.counter = 0


root = Tk()
imgSize = Image.open("ap41.ddr.brf.sdat.bmp")
tkimage =  ImageTk.PhotoImage(imgSize)
w, h = imgSize.size

canvas = Canvas(root, width=w, height=h)
canvas.create_image((w/2,h/2),image=tkimage)
canvas.pack()

root.geometry("%dx%d"%(w,h))
app = Window(root)
root.mainloop()
从tkinter导入*
从PIL导入图像,ImageTk
类窗口(框架):
def uuu init uuu(self,master=None):
帧。\uuuu初始化(自,主)
self.master=master
self.pos=[]
self.master.title(“GUI”)
self.pack(填充=两者,扩展=1)
self.counter=0
菜单=菜单(self.master)
self.master.config(菜单=菜单)
文件=菜单(菜单)
file.add\u命令(label=“Exit”,command=self.client\u Exit)
menu.add_级联(label=“File”,menu=File)
分析=菜单(菜单)
analyze.add_命令(label=“区域
兴趣”,命令=self.regionofindertest)
analyze.add_命令(label=“Erase”,command=self.erasePoints)
menu.add_级联(label=“Analyze”,menu=Analyze)
load=Image.open(“ap41.ddr.brf.sdat.bmp”)
render=ImageTk.PhotoImage(加载)
img=标签(自我,图像=渲染)
img.image=渲染
模拟位置(x=0,y=0)
def RegionFinTerest(自身):
root.config(cursor=“plus”)
canvas.bind(“,self.imgClick)
def点(自身):
self.pos=[]
def客户端_退出(自):
退出()
def imgClick(自身、事件):
如果self.counter<4:
x=canvas.canvasx(event.x)
y=canvas.canvasy(event.y)
self.pos.append((x,y))
打印(self.pos)
画布。创建线(x-5,y,x+5,y,fill=“红色”,
标签=“十字线”)
画布。创建线(x,y-5,x,y+5,fill=“red”,
标签=“十字线”)
self.counter+=1
其他:
canvas.unbind(“”)
root.config(cursor=“arrow”)
self.counter=0
root=Tk()
imgSize=Image.open(“ap41.ddr.brf.sdat.bmp”)
tkimage=ImageTk.PhotoImage(imgSize)
w、 h=imgSize.size
画布=画布(根,宽度=w,高度=h)
canvas.create_image((w/2,h/2),image=tkimage)
canvas.pack()
根几何体(“%dx%d”%(w,h))
app=窗口(根)
root.mainloop()

这里有一些你可以玩和微调的东西,但我认为这将接近你想要做的

首先,我创建了另一个名为
Create eliple
的菜单项,该菜单项链接到一个计算左上角跳线和右下角跳线的方法,然后使用
Create_ovel()
命令在屏幕上创建椭圆。让我知道这是否接近你想要做的

下面的新方法将每个元组的值与基本元组进行比较,如果数字较低,则会更改左上角的跳线,如果数字较高,则会更改右下角的跳线。计算出这两组跳线后,它将创建一个大致符合您选择的椭圆

def createEllipse(self):

    top_left_cords = self.pos[0]
    bottom_right_cords = self.pos[0]
    for pos in self.pos:
        if pos[0] < top_left_cords[0]:
            top_left_cords = (pos[0], top_left_cords[1])

        if pos[1] < top_left_cords[1]:
            top_left_cords = (top_left_cords[0], pos[1])

        if pos[0] > bottom_right_cords[0]:
            bottom_right_cords = (pos[0], bottom_right_cords[1])

        if pos[1] > bottom_right_cords[1]:
            bottom_right_cords = (bottom_right_cords[0], pos[1])
def createEllipse(自):
左上方线缆=自身位置[0]
底部\u右侧\u跳线=自身位置[0]
对于self.pos中的pos:
如果位置[0]<左上电缆[0]:
左上角电缆=(位置[0],左上角电缆[1])
如果位置[1]<左上电缆[1]:
左上角线缆=(左上角线缆[0],位置[1])
如果位置[0]>底部\u右侧\u跳线[0]:
右下角电缆=(位置[0],右下角电缆[1])
如果位置[1]>底部\u右侧\u跳线[1]:
右下角电缆=(右下角电缆[0],位置[1])
以下是完整代码:

from tkinter import *
from PIL import Image, ImageTk

class Window(Frame):

    def __init__(self, master=None):
        Frame.__init__(self, master)

        self.master = master
        self.pos = []
        self.master.title("GUI")
        self.pack(fill=BOTH, expand=1)

        self.counter = 0

        menu = Menu(self.master)
        self.master.config(menu=menu)

        file = Menu(menu)
        file.add_command(label="Exit", command=self.client_exit)
        menu.add_cascade(label="File", menu=file)
        analyze = Menu(menu)

        analyze.add_command(label="Region of Interest",command=self.regionOfInterest)
        analyze.add_command(label="Erase", command=self.erasePoints)
        analyze.add_command(label="Create Ellipse", command=self.createEllipse)

        menu.add_cascade(label="Analyze", menu=analyze)
        load = Image.open("./Colors/1.png")
        render = ImageTk.PhotoImage(load)


        img = Label(self, image=render)
        img.image = render
        img.place(x=0, y=0)

    def createEllipse(self):

        top_left_cords = self.pos[0]
        bottom_right_cords = self.pos[0]
        for pos in self.pos:
            if pos[0] < top_left_cords[0]:
                top_left_cords = (pos[0], top_left_cords[1])

            if pos[1] < top_left_cords[1]:
                top_left_cords = (top_left_cords[0], pos[1])

            if pos[0] > bottom_right_cords[0]:
                bottom_right_cords = (pos[0], bottom_right_cords[1])

            if pos[1] > bottom_right_cords[1]:
                bottom_right_cords = (bottom_right_cords[0], pos[1])

        print(top_left_cords, bottom_right_cords)

        canvas.create_oval(top_left_cords, bottom_right_cords)

    def regionOfInterest(self):
        root.config(cursor="plus")
        canvas.bind("<Button-1>", self.imgClick)

    def erasePoints(self):
        self.pos = []

    def client_exit(self):
        exit()

    def imgClick(self, event):

        if self.counter < 4:
            x = canvas.canvasx(event.x)
            y = canvas.canvasy(event.y)
            self.pos.append((x, y))
            print(self.pos)
            canvas.create_line(x - 5, y, x + 5, y, fill="red", 
tags="crosshair")
            canvas.create_line(x, y - 5, x, y + 5, fill="red", 
tags="crosshair")
            self.counter += 1
        else:
            canvas.unbind("<Button 1>")
            root.config(cursor="arrow")
            self.counter = 0


root = Tk()
imgSize = Image.open("./Colors/1.png")
tkimage =  ImageTk.PhotoImage(imgSize)
w, h = imgSize.size

canvas = Canvas(root, width=w, height=h)
canvas.create_image((w/2,h/2),image=tkimage)
canvas.pack()

root.geometry("%dx%d"%(w,h))
app = Window(root)
root.mainloop()
从tkinter导入*
从PIL导入图像,ImageTk
类窗口(框架):
def uuu init uuu(self,master=None):
帧。\uuuu初始化(自,主)
self.master=master
self.pos=[]
self.master.title(“GUI”)
self.pack(填充=两者,扩展=1)
self.counter=0
菜单=菜单(self.master)
self.master.config(菜单=菜单)
文件=菜单(菜单)
file.add\u命令(label=“Exit”,command=self.client\u Exit)
menu.add_级联(label=“File”,menu=File)
分析=菜单(菜单)
analyze.add_命令(label=“Region of Interest”,command=self.regionofindertest)
analyze.add_命令(label=“Erase”,command=self.erasePoints)
analyze.add_命令(label=“Create eliple”,command=self.createEliple)
menu.add_级联(label=“Analyze”,menu=Analyze)
加载=图像。打开(“./Colors/1.png”)
render=ImageTk.PhotoImage(加载)
img=标签(自我,图像=渲染)
img.image=渲染
模拟位置(x=0,y=0)
def createEllipse(自我):
左上方线缆=自身位置[0]
底部\u右侧\u跳线=自身位置[0]
对于self.pos中的pos:
如果位置[0]<左上电缆[0]:
左上角电缆=(位置[0],左上角电缆[1])
如果位置[1]<左上电缆[1]:
左上角线缆=(左上角线缆[0],位置[1])
如果位置[0]>底部\u右侧\u跳线[0]:
右下角电缆=(位置[0],右下角电缆[1])
如果位置[1]>底部\u右侧\u跳线[1]:
右下角电缆=(右下角电缆[0],位置[1])
打印(左上、右下)
画布。创建椭圆形(顶部左线,底部右线)
def RegionFinTerest(自身):
root.config(cursor=“plus”)
canvas.bind(“,self.imgClick)
def点(自身):
self.pos=[]
def客户端_退出(自):
退出()
def imgClick(自身、事件):
如果self.counter<4:
x=canvas.canvasx(event.x)
y=canvas.canvasy(event.y)
self.pos.append((x,y))
打印(self.pos)
画布。创建线(x-5,y,x+5,y,fill=“红色”,
标签=“十字线”)