Я пытался повторить этот уже отвеченный вопрос Matplotlib - plot_surface: получить значения x, y, z, записанные в правом нижнем углу , но не смог получить тот же результат, как указано там. Итак, у меня есть код вроде:
import numpy as np
from mpl_toolkits.mplot3d import Axes3D
import matplotlib.pyplot as plt
from plyfile import PlyData, PlyElement
#Handle the "onclick" event
def onclick(event):
print('%s click: button=%d, x=%d, y=%d, xdata=%f, ydata=%f' %
('double' if event.dblclick else 'single', event.button,
event.x, event.y, event.xdata, event.ydata))
print(gety(event.xdata, event.ydata))
#copied from /6177895/matplotlib-plotsurface-poluchit-znacheniya-x-y-z-napisannye-v-pravom-nizhnem-uglu
def gety(x,y):
s = ax.format_coord(x,y)
print(s) #here it prints "azimuth=-60 deg, elevation=30deg"
out = ""
for i in range(s.find('y')+2,s.find('z')-2):
out = out+s[i]
return float(out)
#Read a PLY file and prepare it for display
plydata = PlyData.read("some.ply")
mesh = plydata.elements[0]
triangles_as_tuples = [(x[0], x[1], x[2]) for x in plydata['face'].data['vertex_indices']]
polymesh = np.array(triangles_as_tuples)
#Display the loaded triangular mesh in 3D plot
fig = plt.figure()
ax = fig.gca(projection='3d')
ax.plot_trisurf(mesh.data['x'], mesh.data['y'], mesh.data['z'], triangles=polymesh, linewidth=0.2, antialiased=False)
fig.canvas.mpl_connect('button_press_event', onclick)
plt.show()
При этом треугольная поверхность отображается правильно (хотя и медленно). Я могу видеть (x, y, z) координаты поверхности в правом нижнем углу, пока я наводю курсор на график. Но когда я пытаюсь получить эти координаты щелчком мыши (через подключенный обработчик событий), функция ax.format_coord (x, y) возвращает не строку декартовых координат, а строку "azimuth = -60 deg, Высота = 30 градусов ", независимо от того, где на графике я нажимаю, пока поверхность не будет повернута. Затем он возвращает другие значения. Отсюда я полагаю, что это сферические координаты текущего вида, а не точки, по которой щелкают, по какой-то причине ...
Может кто-нибудь узнать, что я делаю не так? Как я могу получить декартовы координаты на поверхности?
К вашему сведению: все это связано с моим предыдущим вопросом Python: Графический ввод в 3D , который считался слишком широким и общим.