文章目录
- Dragon绘制
- Canyon地形可视化
- Earth Graph
Dragon绘制
import shutil
import tarfile
from mayavi import mlab
from os.path import join
dragon_tar_file = tarfile.open('Data/dragon.tar.gz')
dragon_tar_file.extractall('dragon_data')
dragon_tar_file.close()
dragon_ply_file = join('dragon_data', 'dragon_recon', 'dragon_vrip.ply')
mlab.pipeline.surface(mlab.pipeline.open(dragon_ply_file))
mlab.show()
shutil.rmtree('Data/dragon_data')

Canyon地形可视化
import zipfile
import numpy as np
from mayavi import mlab
hgt = zipfile.ZipFile('Data/N36W113.hgt.zip').read('N36W113.hgt')
data = np.fromstring(hgt, '>i2')
data.shape = (3601, 3601)
data = data.astype(np.float32)
data = data[:1000, 900:1900]
data[data == -32768] = data[data > 0].min()
mlab.figure(size=(400, 320), bgcolor=(0.16, 0.28, 0.46))
mlab.surf(data, colormap='gist_earth', warp_scale=0.2,
vmin=1200, vmax=1610)
del data
mlab.view(-5.9, 83, 570, [5.3, 20, 238])
mlab.show()
Earth Graph
import csv
import math
import numpy as np
from mayavi import mlab
from mayavi.sources.builtin_surface import BuiltinSurface
'''读取数据'''
cities = dict()
coords = list()
data = csv.reader(open('Data/cities.csv'))
for line in data:
name, longitude, latitude = line
cities[name] = len(coords)
coords.append((float(longitude), float(latitude)))
'''坐标转换'''
coords = np.array(coords)
latitude, long = coords.T * np.pi / 180
x = np.cos(long) * np.cos(latitude)
y = np.cos(long) * np.sin(latitude)
z = np.sin(long)
'''建立窗口'''
mlab.figure(bgcolor=(0.48, 0.48, 0.48), size=(800, 800))
'''绘制地图'''
sphere = mlab.points3d(0, 0, 0, scale_factor=2,
color=(0.67, 0.77, 0.93),
resolution=1024,
opacity=0.7,
name='Earth')
sphere.actor.property.specular = 0.45
sphere.actor.property.specular_power = 5
sphere.actor.property.backface_culling = True
'''绘制城市'''
points = mlab.points3d(x, y, z, scale_mode='none', scale_factor=0.03, color=(0, 0, 1))
for city, index in cities.items():
label = mlab.text(x[index], y[index], city,
z=z[index], color=(1, 1, 1),
width=0.016 * len(city), name=city)
'''绘制大洲边界'''
continents_src = BuiltinSurface(source='earth', name='Continents')
continents_src.data_source.on_ratio = 2
continents = mlab.pipeline.surface(continents_src, color=(0, 0, 0))
'''绘制赤道'''
theta = np.linspace(0, 2 * np.pi, 100)
x = np.cos(theta)
y = np.sin(theta)
z = np.zeros_like(theta)
mlab.plot3d(x, y, z, color=(1, 1, 1), opacity=0.2, tube_radius=None)
'''绘制两条纬线'''
alpha = math.sqrt(3)/2
mlab.plot3d(x * alpha, y * alpha, z + 0.5, color=(1, 1, 1), opacity=0.2, tube_radius=None)
mlab.plot3d(x * alpha, y * alpha, z - 0.5, color=(1, 1, 1), opacity=0.2, tube_radius=None)
'''显示可交互窗口'''
mlab.view(100, 60, 4, [-0.05, 0, 0])
mlab.show()
