坐标核查——pythonGUI及打包成exe
续上篇
在上一篇文章(坐标核查——判断点是否在多边形内)里,通过python实现的PNPLOY算法可以判断一个点是否在一个多边形区域内。
但是这只是一个简答的test,在实际的应用上,我们应该能对多个点进行核查,并且应该以文本读取的方式进行,甚至可能还要引入多线程来优化运行效率。
由于项目的实际情况是:暂时没有基站站址的坐标集信息。所以现在这个小程序暂时不能用于当前生产,故而没有进行多线程之类的优化,只是简单封装了GUI和打包成exe。
GUI实现——tkinter和ttk库
tkinter和ttk库都是python自带的库。PS:python版本3.7.1。
用主要用三个组件:Label、Entry、Button,以及一个——tkinter.filedialog.askopenfilename()的方法来实现浏览文件。
界面效果如下:
其中三个文本可以点击浏览按钮来在本地文件中选择,也可以手动输入,默认值如上图所示。
如若输入为非绝对路径(例如不是C:\User\xxx.txt,而只是xxx.txt)的话,文本应提前放置在程序所在目录中。
结果文本也是默认生成在同一目录下,并且当有文件名称与结果文本相同时,结果文本的写入会覆盖掉原文件内容。
程序的运行结果是这样:
8说了,上代码。
from tkinter import ttk
from tkinter import *
from tkinter.ttk import *
import tkinter.filedialog
#定义一个点的抽象类
class Point:
lng = ''
lat = ''
def __init__(self, lng, lat):
self.lng = lng
self.lat = lat
# 求点集的外包矩形
def get_polygon_bounds(points):
length = len(points)
top = down = left = right = points[0]
for i in range(1, length):
if points[i].lng > top.lng:
top = points[i]
elif points[i].lng < down.lng:
down = points[i]
else:
pass
if points[i].lat > right.lat:
right = points[i]
elif points[i].lat < left.lat:
left = points[i]
else:
pass
top_left = Point(top.lng, left.lat)
top_right = Point(top.lng, right.lat)
down_right = Point(down.lng, right.lat)
down_left = Point(down.lng, left.lat)
return [top_left, top_right, down_right, down_left]
# 判断点是否在外包矩形外
def is_point_in_rect(point, polygon_bounds):
top_left = polygon_bounds[0]
top_right = polygon_bounds[1]
down_right = polygon_bounds[2]
down_left = polygon_bounds[3]