科学计算三维可视化---TraitsUI与Mayavi实例
TraitsUI与Mayavi实例
一:创建一个简单的TraitsUI与Mayavi实例
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创建场景实例
scene = Instance(MlabSceneModel,())
#建立视图
view = View(
Item("scene",
editor=SceneEditor(scene_class=MayaviScene),
show_label=False,
resizable=True,
height=,
width=,
),
resizable=True
) def __init__(self,**traits):
HasTraits.__init__(self,**traits)
self.generate_data() def generate_data(self):
#建立数据
x,y = mgrid[-::100j,-::100j]
R = *sqrt(x** + y**)
z = sin(R)/R
#绘制数据
self.scene.mlab.surf(x,y,z,colormap="cool") a = ActorViewer()
a.configure_traits()
二:基于交互控制的Mayavi窗口
(一)框架步骤
(二)程序框架
(三)代码实现
(1)定义窗口变量
(2)建立视图的布局
(3)更新视图绘制
(4)定义Curve生成数据
(四)全部代码
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/.
phi = arange(0.0,*pi+0.5*dphin,dphin,'d')
#建立数据
def curve(n_mer,n_long):
mu = phi*n_mer
x = cos(mu)*(+cos(n_long/n_mer)*0.5)
y = sin(mu)*(+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(,,)
n_longitudinal = Range(,,)
#场景模型实例
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=,width=,show_label=False),
Group("_","n_meridional","n_longitudinal"),
resizable=True
) model = MyModel()
model.configure_traits()
科学计算三维可视化---TraitsUI与Mayavi实例的更多相关文章
- 科学计算三维可视化---TraitsUI的介绍
TraitsUI的介绍 Python中存在Tkinter,wxPython,pyQt4等GUI图像界面编写库,这三类库要求程序员掌握众多的GUI API函数 对于科学计算的应用来说,我们希望可以快速的 ...
- 科学计算三维可视化---TraitsUI(控件)
一:文本编辑器 from traits.api import HasTraits,Int,Str,Password from traitsui.api import View,Item,Group,M ...
- 科学计算三维可视化---TraitsUI(配置视图)
配置视图 模态窗口: from traits.api import HasTraits,Int,Strclass ModelManager(HasTraits): model_name = Str c ...
- 科学计算三维可视化---TraitsUI(Group对象组织界面)
使用Group对象组织界面 将一组相关的Item对象组织在一起 from traitsui.api import Group from traits.api import HasTraits,Int, ...
- 科学计算三维可视化---TraitsUI(View定义界面)
View定义界面 使用View来自定义界面 class ModelManager(HasTraits): model_name = Str category = Str model_file = St ...
- Python科学计算三维可视化(整理完结)
中国MOOC<Pyhton计算计算三维可视化>总结 课程url:here ,教师:黄天宇,嵩天 下文的图片和问题,答案都是从eclipse和上完课后总结的,转载请声明. Python数据三 ...
- 科学计算三维可视化---Mlab基础(数据可视化)
推文:科学计算三维可视化---TVTK库可视化实例 使用相关函数:科学计算三维可视化---Mlab基础(管线控制函数) 一:mlab.pipeline中标量数据可视化 通过持续实例,来感受mlab对数 ...
- 科学计算三维可视化---Mlab基础(管线控制函数)
科学计算三维可视化---TVTK管线与数据加载(可视化管线和图像管线了解) 科学计算三维可视化---Mayavi入门(Mayavi管线) Mlab管线控制函数的调用 Sources:数据源 Filte ...
- 科学计算三维可视化---Mlab基础(鼠标选取交互操作)
一:鼠标选取介绍 二:选取红色小球分析 相关方法:科学计算三维可视化---Mlab基础(基于Numpy数组的绘图函数) 1.小球场景初始化建立 import numpy as np from maya ...
随机推荐
- android实战开发02
正如我之前提到的,我想的是网页来进行测试发布是有较大难度的,但是我高兴的看到我的好友limary已经熬出头了,之后我会关注他的进度的,感谢他给我的鼓励和启发.现在我要讲讲我的天才运算器V2.0版. 在 ...
- 树莓派与Arduino Leonardo使用NRF24L01无线模块通信之基于RF24库 (三) 全双工通信
设计思路 Arduino Leonardo初始化为发送模式,发送完成后,立即切换为接收模式,不停的监听,收到数据后立即切换为发送模式,若超过一定时间还为接收到数据,则切换为发送模式. 树莓派初始化为接 ...
- Beta阶段DAY3
一.提供当天站立式会议照片一张 二.每个人的工作 1.讨论项目每个成员的昨天进展 刘阳航:尝试改进UI,美化界面. 林庭亦:调整难度设置. 郑子熙:尝试改进UI,美化界面. 陈文俊:调整难度设置. 2 ...
- Beta阶段——第二篇 Scrum 冲刺博客
i. 提供当天站立式会议照片一张: ii. 每个人的工作 (有work item 的ID) (1) 昨天已完成的工作: 账单收支分明,剩余舍费关联成功 (2) 今天计划完成的工作: 账单删除功能,排序 ...
- syntax error:unexpected end of file
将window上编辑的xxy1.sh脚本上传到linux上,并执行的时候提示 xxy1.sh: line 17: syntax error: unexpected end of file 但是通过ca ...
- [官网]SQLSERVER ON linux 的最低要求 以及安装方法
快速入门:在 Red Hat 上安装 SQL Server 并创建数据库 总体说明: 适用于: SQL Server (仅限 Linux)Azure SQL 数据库Azure SQL 数据仓库并行数据 ...
- hdu 1556 Color the ball(树状数组)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=1556 题意:N个气球排成一排,从左到右依次编号为1,2,3....N.每次给定2个整数[a,b]之间的气球 ...
- Girls' research HDU - 3294(马拉车水题)
题意: 求最长回文串 长度要大于等于2 且输出起点和终点 输出回文串字符 这个字符还是要以给出的字符为起点a 输出 解析: 分析一下s_new串就好了 #include <iostream& ...
- Java多线程相关的
很多小伙伴在学习Java的时候,总是感觉Java多线程在实际的业务中很少使用,以至于不会花太多的时间去学习,技术债不断累积!等到了一定程度的时候对于与Java多线程相关的东西就很难理解,今天需要探讨的 ...
- bzoj2141: 排队(分块+树状数组)
块套树为什么会这么快.. 先跑出原序列逆序对. 显然交换两个位置$l,r$,对$[1,l),(r,n]$里的数没有影响,所以只需要考虑$[l,r]$内的数. 设$(l,r)$内的数$a_i$,则按以下 ...