2016-03-17 1 views
1

J'ai un maillage dans un fichier stl (https://dl.dropboxusercontent.com/u/710615/stlMidpoint.stl)python OpenCV maille Triangulaire ayant des coordonnées

Avec ce code:

from stl import mesh 
import numpy as np 
import matplotlib.pyplot as plt 
from mpl_toolkits.mplot3d import Axes3D 
import cv2 

def unique(a): 
    order = np.lexsort(a.T) 
    a = a[order] 
    diff = np.diff(a, axis=0) 
    ui = np.ones(len(a), 'bool') 
    ui[1:] = (diff != 0).any(axis=1) 

    return a[ui] 

A = np.loadtxt("vectors.txt") 
A = A[np.logical_not(A[:,2] > 0)] 
uniqA = unique(A) 
coordA = A[:,0:2] 

Je suis en mesure d'obtenir les coordonnées qui a la correspondance (je pense) aux points de la surface des triangles. J'essaye de dessiner les triangles sans succès. Les points sont là mais pas sur un format triangles. J'utilise oisifs:

img= cv2.imread('nimg.jpg') 
imgMask = np.ones(img.shape[:2], dtype="uint8")*255 
m_xor= np.ones(imgMask.shape, dtype="uint8") * 255 

points = np.array(uniqA[:,0:2], np.int32) 
print points 
cv2.polylines(m_xor,[points], 1, (0,0,0)) 
cv2.imwrite('result.jpg', m_xor) 

vectors.txt: https://dl.dropboxusercontent.com/u/710615/vectors.txt

NiMg: https://dl.dropboxusercontent.com/u/710615/nimg.jpg

Répondre

2

utilisant numpy-stl (https://github.com/WoLpH/numpy-stl) Je peux ouvrir, lire et rendre le fichier facilement:

from stl import mesh 
from matplotlib import collections 
from matplotlib import pyplot 

# Create a figure and axes 
figure, axes = pyplot.subplots() 

# Read the STL file 
your_mesh = mesh.Mesh.from_file('stlMidPoint.stl') 

# Scale the image to the STL dimensions 
axes.set_xlim(your_mesh.min_[0], your_mesh.max_[0]) 
axes.set_ylim(your_mesh.min_[1], your_mesh.max_[1]) 

# Add the polygons, but only the X and Y axis since it's 2D 
axes.add_collection(collections.PolyCollection(your_mesh.vectors[:, :, :2])) 

# Make sure the aspect ratio stays correct 
pyplot.gca().set_aspect('equal') 

# Render! 
pyplot.show() 

La taille énorme le rend vraiment lent cependant.

enter image description here

+0

Comment puis-je exporter en tant que vecteur numpy et overtlay dans d'autres images? Par exemple, comment puis-je appliquer ce maillage sur cette image https://dl.dropboxusercontent.com/u/710615/La1.png , par exemple. Extraction du tableau numpy en utilisant matplotlib Je vais obtenir les points, pas les triangles. – marco

+0

Vous pouvez utiliser 'figure.savefig ('image.png', dpi = ...)' pour stocker l'image en tant qu'image haute résolution. Ou utilisez 'fig.canvas' pour accéder directement aux données. Le vecteur est en fait déjà disponible via 'your_mesh.vectors [:,:,: 2]' – Wolph

+0

Connaissez-vous un moyen de dessiner dans un autre contexte différent de matplotlib? – marco