我用Axes3d.plot_wireframe
绘制磁盘的离散化表面,并在同一张图上使用Axes3d.scatter
叠加一个与磁盘中心相对应的点(附图)。我的问题是,只有在侧面看到光盘时,点才可见。我希望它是可见的,无论什么观点。我也加入了我的脚本的一部分(抱歉,如果它看起来不应该)。在
我尝试改变脚本中绘图的顺序,尝试在两个绘图中添加'zorder'
参数,还尝试更改散点图中的标记大小,但没有成功。在
import matplotlib as mpl
from mpl_toolkits.mplot3d import Axes3D
import pylab as plt
import numpy as np
# data to build the disc
r = np.linspace(0, 5e-3, 30)
psi = np.linspace(0, 2*np.pi, 30)
n = np.array([0.70710678, 0, 0.70710678])
e2 = np.array([0.70710678, 0, -0.70710678])
e3 = np.array([0, 1, 0])
Oc = np.array([0, 0, 0])
R, PSI = np.meshgrid(r, psi)
OpP = np.zeros((len(r),len(psi),3), dtype=float)
OpP[:,:,0] = np.zeros((len(r),len(psi)), dtype=float)
OpP[:,:,1] = R*np.cos(PSI)
OpP[:,:,2] = R*np.sin(PSI)
Mrot = np.zeros((3,3), dtype=float)
Mrot[0,:] = n
Mrot[1,:] = e2
Mrot[2,:] = e3
Ocx = Oc[0]; Ocy = Oc[1]; Ocz = Oc[2]
xp = Ocx + np.dot(OpP, Mrot)[:,:,0]
yp = Ocy + np.dot(OpP, Mrot)[:,:,1]
zp = Ocz + np.dot(OpP, Mrot)[:,:,2]
# Plotting
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
ax.plot_wireframe(zp,yp,xp, label='piston')
ax.scatter(Ocz, Ocy, Ocx, zdir='z', s=40, color='red', label='Oc')
plt.gca().invert_yaxis()
plt.legend()
plt.show()
可以设置绘图参数的某些值,以获得更好的绘图效果。尝试用以下内容替换相关代码行:
相关问题 更多 >
编程相关推荐