X-Git-Url: http://git.salome-platform.org/gitweb/?p=modules%2Fsmesh.git;a=blobdiff_plain;f=src%2FTools%2FblocFissure%2Fgmu%2FcreePointsPipePeau.py;h=e13105eb776e096ec4e49b2a9ea18b18993f7741;hp=9daf6ac04bf1715e7b167c8a61c2d3ed5f6e88ae;hb=f44efbc02056a2734440b736789b8cfa380430bb;hpb=71de383cb614e31ded6aa6343c052fbd8335b472 diff --git a/src/Tools/blocFissure/gmu/creePointsPipePeau.py b/src/Tools/blocFissure/gmu/creePointsPipePeau.py index 9daf6ac04..e13105eb7 100644 --- a/src/Tools/blocFissure/gmu/creePointsPipePeau.py +++ b/src/Tools/blocFissure/gmu/creePointsPipePeau.py @@ -17,35 +17,34 @@ # # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com # +"""création des points du maillage du pipe sur la face de peau""" import logging +from . import initLog from .geomsmesh import geompy from .geomsmesh import geomPublish from .geomsmesh import geomPublishInFather -from . import initLog from .projettePointSurCourbe import projettePointSurCourbe def creePointsPipePeau(listEdges, idFacesDebouchantes, idFillingFromBout, ptEdgeFond, ptFisExtPi, edCircPeau, gptsdisks, idisklim, nbsegRad): - """ - création des points du maillage du pipe sur la face de peau - """ + """création des points du maillage du pipe sur la face de peau""" logging.info('start') - - for i, edges in enumerate(listEdges): - idf = idFacesDebouchantes[i] # indice de face débouchante (facesPipePeau) + + for n_edges, edges in enumerate(listEdges): + idf = idFacesDebouchantes[n_edges] # indice de face débouchante (facesPipePeau) if idf >= 0: - gptdsk = [] + gptdsk = list() if idf > 0: # idf vaut 0 ou 1 idf = -1 # si idf vaut 1, on prend le dernier élément de la liste (1 ou 2 extrémités débouchent sur la face) - centre = ptEdgeFond[idFillingFromBout[i]][idf] + centre = ptEdgeFond[idFillingFromBout[n_edges]][idf] name = "centre%d"%idf geomPublish(initLog.debug, centre, name) - vertPipePeau = ptFisExtPi[idFillingFromBout[i]][idf] + vertPipePeau = ptFisExtPi[idFillingFromBout[n_edges]][idf] geomPublishInFather(initLog.debug, centre, vertPipePeau, "vertPipePeau") - grpsEdgesCirc = edCircPeau[idFillingFromBout[i]] # liste de groupes - edgesCirc = [] + grpsEdgesCirc = edCircPeau[idFillingFromBout[n_edges]] # liste de groupes + edgesCirc = list() for grpEdgesCirc in grpsEdgesCirc: edgesCirc += geompy.ExtractShapes(grpEdgesCirc, geompy.ShapeType["EDGE"], False) for k, edge in enumerate(edges): @@ -59,32 +58,31 @@ def creePointsPipePeau(listEdges, idFacesDebouchantes, idFillingFromBout, distEdgeCirc = [(geompy.MinDistance(bout, edgeCirc), k2, edgeCirc) for k2, edgeCirc in enumerate(edgesCirc)] distEdgeCirc.sort() logging.debug("distEdgeCirc: %s", distEdgeCirc) - u = projettePointSurCourbe(bout, distEdgeCirc[0][2]) - if (abs(u) < 0.02) or (abs(1-u) < 0.02): # les points très proches d'une extrémité doivent y être mis précisément. + dist = projettePointSurCourbe(bout, distEdgeCirc[0][2]) + if (abs(dist) < 0.02) or (abs(1.-dist) < 0.02): # les points très proches d'une extrémité doivent y être mis précisément. extrCircs = geompy.ExtractShapes(distEdgeCirc[0][2], geompy.ShapeType["VERTEX"], True) if geompy.MinDistance(bout, extrCircs[0]) < geompy.MinDistance(bout, extrCircs[1]): bout = extrCircs[0] else: bout = extrCircs[1] else: - bout = geompy.MakeVertexOnCurve(distEdgeCirc[0][2], u) + bout = geompy.MakeVertexOnCurve(distEdgeCirc[0][2], dist) name ="bout%d"%k geomPublishInFather(initLog.debug, centre, bout, name) # enregistrement des points dans la structure - points = [] - for j in range(nbsegRad +1): - u = j/float(nbsegRad) - points.append(geompy.MakeVertexOnCurve(edge, u)) + points = list() + for n_seg in range(nbsegRad +1): + points.append(geompy.MakeVertexOnCurve(edge, float(n_seg)/float(nbsegRad))) if geompy.MinDistance(bout, points[0]) < geompy.MinDistance(centre, points[0]): points.reverse() points[0] = centre points[-1] = bout gptdsk.append(points) - if i == 0: + if n_edges == 0: gptsdisks[idisklim[0] -1] = gptdsk idisklim[0] = idisklim[0] -1 else: gptsdisks[idisklim[1] +1] = gptdsk idisklim[1] = idisklim[1] +1 - - return (gptsdisks, idisklim) \ No newline at end of file + + return (gptsdisks, idisklim)