はじめに
3D形式のデータをもつstlファイルをボクセル形式に変換して、matplotlib のvoxelで表示する。
コード
data:image/s3,"s3://crabby-images/0e0b2/0e0b2024dfcccb36f51858430fbd80e3f3e64356" alt=""
解説
stlファイルのダウンロード
data:image/s3,"s3://crabby-images/07ea9/07ea9a67dfa61794f5837c8f6164cb3446b1e5d9" alt=""
Thingiverse - Digital Designs for Physical Objects
Download millions of 3D models and files for your 3D printer, laser cutter, or CNC. From custom parts to unique designs,...
上記サイトからstlファイルをダウンロードして、下記サイトでボクセル形式に変換し、txtデータとして、ダウンロードした。
data:image/s3,"s3://crabby-images/7b79d/7b79d6e9c0b3ff9a441e6d48408fb8a91d84c565" alt=""
online html5 voxelizer
convert your 3D model or image into voxels
モジュールのインポート
データの読み込み
np.loadtxt(‘Cactus1.txt’,delimiter=’,’)と、ファイル名と区切りの形式を指定して読み込む。データの構造としては、(#,#,#)のデータが1列に連なったデータとなっている。
ボクセルデータの生成
dataの最大値を求めて、最大値+1のnp.indices()配列を生成する。ここでは、形状が(61,61,61)の、要素としてインデックスをもつ配列を作成し、それをそのまま、x,y,zとしている。
x[int(data[i,0]),int(data[i,1]),int(data[i,2])] = -1のfor文で、データと適合するx,y,zの位置を-1に変換する。適合する位置をすべて-1にしてから、voxels = x < 0 とすることで、voxelはdataの位置のみがTrueとなったbool型配列となる。
3Dグラフの表示
ax = fig.gca(projection=’3d’)で3Dグラフが表示できるようになる。
ax.set_aspect(‘equal’)でx,y,zの比率を揃えている。
ax.voxels(voxels, linewidth=0.3, facecolor=’lightgreen’,edgecolors=’k’)でボクセルを表示。
ax.view_init(elev=-160, azim=30)で視点の設定を行っている。
ax.set_axis_off()で軸を非表示にした。
その他の例
data:image/s3,"s3://crabby-images/66621/666219d9555528370bfb36600bd9d4c5e1aa1edc" alt=""
data:image/s3,"s3://crabby-images/42222/422227401468a0c5f4faa08fead2d05a47660d8a" alt=""
data:image/s3,"s3://crabby-images/9c282/9c28202e20d21dbc4dc8e92e2107931d76aa9e53" alt=""
参考
data:image/s3,"s3://crabby-images/07ea9/07ea9a67dfa61794f5837c8f6164cb3446b1e5d9" alt=""
Thingiverse - Digital Designs for Physical Objects
Download millions of 3D models and files for your 3D printer, laser cutter, or CNC. From custom parts to unique designs,...
data:image/s3,"s3://crabby-images/7b79d/7b79d6e9c0b3ff9a441e6d48408fb8a91d84c565" alt=""
online html5 voxelizer
convert your 3D model or image into voxels
コメント
[…] [matplotlib 3D] 47.ボクセルサボテン(Voxel Cactus)3D形式のデータをもつstlファイルをボクセル形式に変換して、matplotlib のvoxelで表示する。sabopy.com2019.03.14 […]