Diff
checker
テキスト
テキスト
画像
ドキュメント
Excel
フォルダ
Legal
Enterprise
デスクトップ
料金
ログイン
Diffchecker デスクトップのダウンロード
テキスト比較
2 つのテキスト ファイルの違いを見つける
ツール
履歴
ライブエディター
空白の変更を非表示
未変更行を折りたたむ
折り返しなし
レイアウト
分割
統合
比較精度
スマート
単語
文字
テキストスタイル
外観を変更
シンタックスハイライト
構文を選択
無視
テキスト変換
最初の差分へ移動
入力を編集
Diffchecker Desktop
Diffcheckerを実行する最も安全な方法。Diffchecker Desktopアプリを入手:あなたの差分はコンピューターから出ることはありません!
Desktopを入手
SplitMeshLargeDiff
作成日
2 年前
差分は期限切れになりません
クリア
エクスポート
共有
説明
3 削除
行
合計
削除
文字
合計
削除
この機能を引き続き使用するには、アップグレードしてください
Diff
checker
Pro
価格を見る
104 行
すべてコピー
4 追加
行
合計
追加
文字
合計
追加
この機能を引き続き使用するには、アップグレードしてください
Diff
checker
Pro
価格を見る
104 行
すべてコピー
import rhinoscriptsyntax as rs
import rhinoscriptsyntax as rs
import Rhino as rhino
import Rhino as rhino
import scriptcontext as sc
import scriptcontext as sc
__commandname__ = "splitMeshLarge"
__commandname__ = "splitMeshLarge"
def RunCommand( is_interactive ):
def RunCommand( is_interactive ):
curr_doc = sc.doc
curr_doc = sc.doc
filter = rhino.DocObjects.ObjectType.Mesh
filter = rhino.DocObjects.ObjectType.Mesh
rc, objrefs = rhino.Input.RhinoGet.GetMultpileObjects("Select Meshs to split", False, filter)
rc, objrefs = rhino.Input.RhinoGet.GetMultpileObjects("Select Meshs to split", False, filter)
コピー
コピー済み
コピー
コピー済み
for objref in objrefs
for objref in objrefs
:
old_
mesh=objref.Mesh()
mesh=objref.Mesh()
if
old_
mesh.IsClosed:
if
mesh.IsClosed:
print("Your Mesh is already closed')
print("Your Mesh is already closed')
return
return
コピー
コピー済み
コピー
コピー済み
mesh.
old_mesh.
DuplicateMesh()
mesh.
DuplicateMesh()
mesh.Vertices.CombineIdentical(True,True)
mesh.Vertices.CombineIdentical(True,True)
curr_doc.Objects.Replace(objref,mesh)
curr_doc.Objects.Replace(objref,mesh)
meshTopologyEdgeList = mesh.TopologyEdges
meshTopologyEdgeList = mesh.TopologyEdges
meshTopologyVertexList = mesh.TopologyVertices
meshTopologyVertexList = mesh.TopologyVertices
verticesNakedDict = mesh.GetNakedEdgePointStatus()
verticesNakedDict = mesh.GetNakedEdgePointStatus()
nakedEdges = []
nakedEdges = []
nakedEdgePoints = []
nakedEdgePoints = []
nakedEdgeLengths = []
nakedEdgeLengths = []
for i in range(meshTopologyEdgeList.Count):
for i in range(meshTopologyEdgeList.Count):
pairVertices = meshTopologyEdgeList.GetTopologyVertices(i)
pairVertices = meshTopologyEdgeList.GetTopologyVertices(i)
index1 = pairVertices[0]
index1 = pairVertices[0]
index2 = pairVertices[1]
index2 = pairVertices[1]
if verticesNakedDict[index1] and verticesNakedDict[index2]:
if verticesNakedDict[index1] and verticesNakedDict[index2]:
pt1=mesh.Vertices[index1]
pt1=mesh.Vertices[index1]
pt2=mesh.Vertices[index2]
pt2=mesh.Vertices[index2]
nakedEdgePoints.append([pt1,pt2])
nakedEdgePoints.append([pt1,pt2])
nakedEdges.append(i)
nakedEdges.append(i)
line = rhino.Geometry.Line(pt1,pt2)
line = rhino.Geometry.Line(pt1,pt2)
nakedEdgeLengths.append(line.Length)
nakedEdgeLengths.append(line.Length)
ignoreVar, nakedEdges = zip(*sorted(zip(nakedEdgeLengths, nakedEdges), reverse=True))
ignoreVar, nakedEdges = zip(*sorted(zip(nakedEdgeLengths, nakedEdges), reverse=True))
ignoreVar, nakedEdgePoints = zip(*sorted(zip(nakedEdgeLenghts, nakedEdgePoints), reverse=True))
ignoreVar, nakedEdgePoints = zip(*sorted(zip(nakedEdgeLenghts, nakedEdgePoints), reverse=True))
for i in range(len(nakedEdges)):
for i in range(len(nakedEdges)):
pairVertices = meshTopologyEdgeList.GetTopologyVertices(nakedEdges[i])
pairVertices = meshTopologyEdgeList.GetTopologyVertices(nakedEdges[i])
testpt = nakedEdgePoints[i][0]
testpt = nakedEdgePoints[i][0]
for counter,vertex in enumerate(mesh.Vertices):
for counter,vertex in enumerate(mesh.Vertices):
if vertex == nakedEdgePoints[i][0]:
if vertex == nakedEdgePoints[i][0]:
index1=counter
index1=counter
elif vertex == nakedEdgePoints[i][1]:
elif vertex == nakedEdgePoints[i][1]:
index2=counter
index2=counter
line = rhino.Geometry.Line(mesh.Vertices[index1], mesh.Vertices[index2])
line = rhino.Geometry.Line(mesh.Vertices[index1], mesh.Vertices[index2])
bb = line.BoundingBox
bb = line.BoundingBox
rs.ZoomBoundingBox(bb)
rs.ZoomBoundingBox(bb)
line_GUID = curr_doc.Objects.AddLine(line)
line_GUID = curr_doc.Objects.AddLine(line)
rs.SelectObject(line_GUID)
rs.SelectObject(line_GUID)
コピー
コピー済み
コピー
コピー済み
curr_doc.View
.Redraw()
curr_doc.View
s
.Redraw()
gi=rhino.Input.Custom.GetInteger()
gi=rhino.Input.Custom.GetInteger()
gi.SetCommandPrompt('How many times should we split this edge')
gi.SetCommandPrompt('How many times should we split this edge')
gi.SetCommandPromptDefault('0')
gi.SetCommandPromptDefault('0')
gi.SetDefaultInteger(0)
gi.SetDefaultInteger(0)
gi.AddOption('Exit')
gi.AddOption('Exit')
gi.SetLowerLimit(0, False)
gi.SetLowerLimit(0, False)
gi.SetUpperLimit(9,False)
gi.SetUpperLimit(9,False)
get_gi = gi.Get()
get_gi = gi.Get()
if gi.CommandResult()!=rhino.Commands.Result.Success:
if gi.CommandResult()!=rhino.Commands.Result.Success:
curr_doc.Objects.Delete(line_GUID,True)
curr_doc.Objects.Delete(line_GUID,True)
return
return
if get_gi == rhino.Input.GetResult.Number:
if get_gi == rhino.Input.GetResult.Number:
curr_doc.Objects.Delete(line_GUID,True)
curr_doc.Objects.Delete(line_GUID,True)
numSplits = gi.Number()
numSplits = gi.Number()
elif get_gi == rhino.Input.GetResult.Option:
elif get_gi == rhino.Input.GetResult.Option:
curr_doc.Objects.Delete(line_GUID,True)
curr_doc.Objects.Delete(line_GUID,True)
print('User exited')
print('User exited')
return
return
if numSplits==0:
if numSplits==0:
continue
continue
edgeTopoIndex = meshTopologyEdgeList.GetEdgeIndex(index1,index2)
edgeTopoIndex = meshTopologyEdgeList.GetEdgeIndex(index1,index2)
for j in range(numSplits):
for j in range(numSplits):
splitPercentage = (j+1)/(numSplits+1)
splitPercentage = (j+1)/(numSplits+1)
edgeTopoIndex = meshTopologyEdgeList.GetEdgeIndex(index1,index2)
edgeTopoIndex = meshTopologyEdgeList.GetEdgeIndex(index1,index2)
print(meshTopologyEdgeList.Count)
print(meshTopologyEdgeList.Count)
flag = meshTopologyEdgeList.SplitEdge(edgeTopoIndex,splitPercentage) #THE ISSUE IS HERE!!
flag = meshTopologyEdgeList.SplitEdge(edgeTopoIndex,splitPercentage) #THE ISSUE IS HERE!!
print(meshTopologyEdgeList.Count)
print(meshTopologyEdgeList.Count)
print(flag)
print(flag)
curr_doc.Objects.Replace(objref,mesh)
curr_doc.Objects.Replace(objref,mesh)
コピー
コピー済み
コピー
コピー済み
curr_doc.View
.Redraw()
curr_doc.View
s
.Redraw()
if flag!=False:
if flag!=False:
meshTopologyEdgeList = meshTopologyEdges
meshTopologyEdgeList = meshTopologyEdges
old_index1 = index1
old_index1 = index1
index1 = mesh.Vertices.Count-1
index1 = mesh.Vertices.Count-1
verticesNakedDict = mesh.GetNakedEdgePointStatus()
verticesNakedDict = mesh.GetNakedEdgePointStatus()
edgeTopoIndex = meshTopologyEdgeList.GetEdgeIndex(index1,index2)
edgeTopoIndex = meshTopologyEdgeList.GetEdgeIndex(index1,index2)
else:
else:
print('Script error')
print('Script error')
return
return
curr_doc.Objects.Replace(objref,mesh)
curr_doc.Objects.Replace(objref,mesh)
コピー
コピー済み
コピー
コピー済み
curr_doc.View
.Redraw()
curr_doc.View
s
.Redraw()
print('All done with naked Edges')
print('All done with naked Edges')
RunCommand(True)
RunCommand(True)
保存された差分
原文
ファイルを開く
import rhinoscriptsyntax as rs import Rhino as rhino import scriptcontext as sc __commandname__ = "splitMeshLarge" def RunCommand( is_interactive ): curr_doc = sc.doc filter = rhino.DocObjects.ObjectType.Mesh rc, objrefs = rhino.Input.RhinoGet.GetMultpileObjects("Select Meshs to split", False, filter) for objref in objrefs old_mesh=objref.Mesh() if old_mesh.IsClosed: print("Your Mesh is already closed') return mesh.old_mesh.DuplicateMesh() mesh.Vertices.CombineIdentical(True,True) curr_doc.Objects.Replace(objref,mesh) meshTopologyEdgeList = mesh.TopologyEdges meshTopologyVertexList = mesh.TopologyVertices verticesNakedDict = mesh.GetNakedEdgePointStatus() nakedEdges = [] nakedEdgePoints = [] nakedEdgeLengths = [] for i in range(meshTopologyEdgeList.Count): pairVertices = meshTopologyEdgeList.GetTopologyVertices(i) index1 = pairVertices[0] index2 = pairVertices[1] if verticesNakedDict[index1] and verticesNakedDict[index2]: pt1=mesh.Vertices[index1] pt2=mesh.Vertices[index2] nakedEdgePoints.append([pt1,pt2]) nakedEdges.append(i) line = rhino.Geometry.Line(pt1,pt2) nakedEdgeLengths.append(line.Length) ignoreVar, nakedEdges = zip(*sorted(zip(nakedEdgeLengths, nakedEdges), reverse=True)) ignoreVar, nakedEdgePoints = zip(*sorted(zip(nakedEdgeLenghts, nakedEdgePoints), reverse=True)) for i in range(len(nakedEdges)): pairVertices = meshTopologyEdgeList.GetTopologyVertices(nakedEdges[i]) testpt = nakedEdgePoints[i][0] for counter,vertex in enumerate(mesh.Vertices): if vertex == nakedEdgePoints[i][0]: index1=counter elif vertex == nakedEdgePoints[i][1]: index2=counter line = rhino.Geometry.Line(mesh.Vertices[index1], mesh.Vertices[index2]) bb = line.BoundingBox rs.ZoomBoundingBox(bb) line_GUID = curr_doc.Objects.AddLine(line) rs.SelectObject(line_GUID) curr_doc.View.Redraw() gi=rhino.Input.Custom.GetInteger() gi.SetCommandPrompt('How many times should we split this edge') gi.SetCommandPromptDefault('0') gi.SetDefaultInteger(0) gi.AddOption('Exit') gi.SetLowerLimit(0, False) gi.SetUpperLimit(9,False) get_gi = gi.Get() if gi.CommandResult()!=rhino.Commands.Result.Success: curr_doc.Objects.Delete(line_GUID,True) return if get_gi == rhino.Input.GetResult.Number: curr_doc.Objects.Delete(line_GUID,True) numSplits = gi.Number() elif get_gi == rhino.Input.GetResult.Option: curr_doc.Objects.Delete(line_GUID,True) print('User exited') return if numSplits==0: continue edgeTopoIndex = meshTopologyEdgeList.GetEdgeIndex(index1,index2) for j in range(numSplits): splitPercentage = (j+1)/(numSplits+1) edgeTopoIndex = meshTopologyEdgeList.GetEdgeIndex(index1,index2) print(meshTopologyEdgeList.Count) flag = meshTopologyEdgeList.SplitEdge(edgeTopoIndex,splitPercentage) #THE ISSUE IS HERE!! print(meshTopologyEdgeList.Count) print(flag) curr_doc.Objects.Replace(objref,mesh) curr_doc.View.Redraw() if flag!=False: meshTopologyEdgeList = meshTopologyEdges old_index1 = index1 index1 = mesh.Vertices.Count-1 verticesNakedDict = mesh.GetNakedEdgePointStatus() edgeTopoIndex = meshTopologyEdgeList.GetEdgeIndex(index1,index2) else: print('Script error') return curr_doc.Objects.Replace(objref,mesh) curr_doc.View.Redraw() print('All done with naked Edges') RunCommand(True)
変更されたテキスト
ファイルを開く
import rhinoscriptsyntax as rs import Rhino as rhino import scriptcontext as sc __commandname__ = "splitMeshLarge" def RunCommand( is_interactive ): curr_doc = sc.doc filter = rhino.DocObjects.ObjectType.Mesh rc, objrefs = rhino.Input.RhinoGet.GetMultpileObjects("Select Meshs to split", False, filter) for objref in objrefs: mesh=objref.Mesh() if mesh.IsClosed: print("Your Mesh is already closed') return mesh.DuplicateMesh() mesh.Vertices.CombineIdentical(True,True) curr_doc.Objects.Replace(objref,mesh) meshTopologyEdgeList = mesh.TopologyEdges meshTopologyVertexList = mesh.TopologyVertices verticesNakedDict = mesh.GetNakedEdgePointStatus() nakedEdges = [] nakedEdgePoints = [] nakedEdgeLengths = [] for i in range(meshTopologyEdgeList.Count): pairVertices = meshTopologyEdgeList.GetTopologyVertices(i) index1 = pairVertices[0] index2 = pairVertices[1] if verticesNakedDict[index1] and verticesNakedDict[index2]: pt1=mesh.Vertices[index1] pt2=mesh.Vertices[index2] nakedEdgePoints.append([pt1,pt2]) nakedEdges.append(i) line = rhino.Geometry.Line(pt1,pt2) nakedEdgeLengths.append(line.Length) ignoreVar, nakedEdges = zip(*sorted(zip(nakedEdgeLengths, nakedEdges), reverse=True)) ignoreVar, nakedEdgePoints = zip(*sorted(zip(nakedEdgeLenghts, nakedEdgePoints), reverse=True)) for i in range(len(nakedEdges)): pairVertices = meshTopologyEdgeList.GetTopologyVertices(nakedEdges[i]) testpt = nakedEdgePoints[i][0] for counter,vertex in enumerate(mesh.Vertices): if vertex == nakedEdgePoints[i][0]: index1=counter elif vertex == nakedEdgePoints[i][1]: index2=counter line = rhino.Geometry.Line(mesh.Vertices[index1], mesh.Vertices[index2]) bb = line.BoundingBox rs.ZoomBoundingBox(bb) line_GUID = curr_doc.Objects.AddLine(line) rs.SelectObject(line_GUID) curr_doc.Views.Redraw() gi=rhino.Input.Custom.GetInteger() gi.SetCommandPrompt('How many times should we split this edge') gi.SetCommandPromptDefault('0') gi.SetDefaultInteger(0) gi.AddOption('Exit') gi.SetLowerLimit(0, False) gi.SetUpperLimit(9,False) get_gi = gi.Get() if gi.CommandResult()!=rhino.Commands.Result.Success: curr_doc.Objects.Delete(line_GUID,True) return if get_gi == rhino.Input.GetResult.Number: curr_doc.Objects.Delete(line_GUID,True) numSplits = gi.Number() elif get_gi == rhino.Input.GetResult.Option: curr_doc.Objects.Delete(line_GUID,True) print('User exited') return if numSplits==0: continue edgeTopoIndex = meshTopologyEdgeList.GetEdgeIndex(index1,index2) for j in range(numSplits): splitPercentage = (j+1)/(numSplits+1) edgeTopoIndex = meshTopologyEdgeList.GetEdgeIndex(index1,index2) print(meshTopologyEdgeList.Count) flag = meshTopologyEdgeList.SplitEdge(edgeTopoIndex,splitPercentage) #THE ISSUE IS HERE!! print(meshTopologyEdgeList.Count) print(flag) curr_doc.Objects.Replace(objref,mesh) curr_doc.Views.Redraw() if flag!=False: meshTopologyEdgeList = meshTopologyEdges old_index1 = index1 index1 = mesh.Vertices.Count-1 verticesNakedDict = mesh.GetNakedEdgePointStatus() edgeTopoIndex = meshTopologyEdgeList.GetEdgeIndex(index1,index2) else: print('Script error') return curr_doc.Objects.Replace(objref,mesh) curr_doc.Views.Redraw() print('All done with naked Edges') RunCommand(True)
違いを見つける