TraitsUI与Mayavi实例

本文介绍了使用TraitsUI和Mayavi进行三维数据可视化的两个实例。首先通过一个简单示例展示了如何利用TraitsUI和Mayavi快速搭建交互式三维场景;其次,通过一个更复杂的实例演示了如何基于用户输入参数动态更新三维曲线。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 TraitsUI与Mayavi实例

一:创建一个简单的TraitsUI与Mayavi实例

# -*- coding: utf-8 -*-
from numpy import sqrt,sin,mgrid
from traits.api import HasTraits,Instance
from traitsui.api import View,Item
from tvtk.pyface.scene_editor import SceneEditor
from mayavi.tools.mlab_scene_model import MlabSceneModel
from mayavi.core.ui.mayavi_scene import MayaviScene

#1创建HasTraits继承类
class ActorViewer(HasTraits):
    #1.1创建场景实例
    scene = Instance(MlabSceneModel,())
    #建立视图
    view = View(
        Item("scene",
             editor=SceneEditor(scene_class=MayaviScene),
             show_label=False,
             resizable=True,
             height=500,
             width=500,
             ),
        resizable=True
    )

    def __init__(self,**traits):
        HasTraits.__init__(self,**traits)
        self.generate_data()

    def generate_data(self):
        #建立数据
        x,y = mgrid[-2:2:100j,-2:2:100j]
        R = 10*sqrt(x**2 + y**2)
        z = sin(R)/R
        #绘制数据
        self.scene.mlab.surf(x,y,z,colormap="cool")

a = ActorViewer()
a.configure_traits()

二:基于交互控制的Mayavi窗口

(一)框架步骤

(二)程序框架

 

(三)代码实现

(1)定义窗口变量

 

(2)建立视图的布局

(3)更新视图绘制

(4)定义Curve生成数据

 

(四)全部代码

# -*- coding: utf-8 -*-
# http://www.cnblogs.com/ssyfj/p/9310931.html

from numpy import cos,sin,pi,arange
from traits.api import HasTraits,Instance,Range,on_trait_change
from traitsui.api import View,Item,Group
from mayavi.core.ui.api import MayaviScene,SceneEditor,MlabSceneModel
from mayavi.core.api import PipelineBase

dphin = pi/300.
phi = arange(0.0,2*pi+0.5*dphin,dphin,'d')
#建立数据
def curve(n_mer,n_long):
    mu = phi*n_mer
    x = cos(mu)*(1+cos(n_long/n_mer)*0.5)
    y = sin(mu)*(1+cos(n_long/n_mer)*0.5)
    z = 0.5*sin(n_long*mu/n_mer)
    t = sin(mu)
    return x,y,z,t

class MyModel(HasTraits):
    n_meridional = Range(0,30,6)
    n_longitudinal = Range(0,30,11)
    #场景模型实例
    scene = Instance(MlabSceneModel,()) #后面加上()是将他实例化了
    #管线实例
    plot = Instance(PipelineBase)

    def __init__(self,**traits):
        HasTraits.__init__(self,**traits)
        x, y, z, t = curve(self.n_meridional, self.n_longitudinal)
        if self.plot is None:  # 如果plot未绘制则输出plot3d
            self.plot = self.scene.mlab.plot3d(x, y, z, t,
                                               tube_radius=0.025, colormap="Spectral")

    #当场景被激活,或者参数发生改变,更新图像
    @on_trait_change(['n_meridional','n_longitudinal'])     #似乎监听scene.activated也可以实现在生成scene时计进入下面函数方法
    def update_plot(self):
        x, y, z, t = curve(self.n_meridional, self.n_longitudinal)

        if self.plot is None:  # 如果plot未绘制则输出plot3d
            self.plot = self.scene.mlab.plot3d(x, y, z, t,
                                               tube_radius=0.025, colormap="Spectral")
        else:  # 如果没有数据变化,将数据更新,重新赋值
            self.plot.mlab_source.set(
                x=x, y=y, z=z, scalars=t
            )

    #建立视图布局
    view = View(
        Item("scene",editor=SceneEditor(scene_class=MayaviScene),
             height=250,width=300,show_label=False),
        Group("_","n_meridional","n_longitudinal"),
        resizable=True
    )

model = MyModel()
model.configure_traits()

 

用mlab快速绘图:

# -*- coding: utf-8 -*-

from mayavi import mlab
import numpy as np

x, y = np.ogrid[-2:2:20j, -2:2:20j]
z = x * np.exp( - x**2 - y**2)

pl = mlab.surf(x, y, z, warp_scale="auto")
mlab.axes(xlabel='x', ylabel='y', zlabel='z')
mlab.outline(pl)
mlab.show()

_images/numpy_intro_04.png

将Mayavi嵌入到界面中:

# -*- coding: utf-8 -*-
from traits.api import *
from traitsui.api import View,Item,VGroup

from tvtk.pyface.scene_editor import SceneEditor
from mayavi.tools.mlab_scene_model import MlabSceneModel
from mayavi.core.ui.mayavi_scene import MayaviScene


class DemoApp(HasTraits):
    plotbutton = Button(u"绘图")
    scene = Instance(MlabSceneModel,())
    #建立视图
    view = View(
        VGroup(
            Item(name='scene',
                 editor=SceneEditor(scene_class=MayaviScene),  # 设置mayavi的编辑器
                 resizable=True,
                 height=250,
                 width=400
                 ),
            'plotbutton',
            show_labels=False
        ),
        title=u"在TraitsUI中嵌入Mayavi"
    )

    def _plotbutton_fired(self):
        self.plot()

    def plot(self):
        g = self.scene.mlab.test_mesh()


app = DemoApp()
app.configure_traits()

 

转载于:https://my.oschina.net/u/2245781/blog/1860584

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值