关于tkCommand的各种事件的解释
superclass for callback/observer methods
vtkCommand is an implementation of the observer/command design pattern. In this design pattern, any instance of vtkObject can be "observed" for any events it might invoke. For example, vtkRenderer invokes a StartEvent as it begins to render and a EndEvent when it finishes rendering. Filters (subclasses of vtkProcessObject) invoke StartEvent, ProgressEvent, and EndEvent as the filter processes data. Observers of events are added with the AddObserver() method found in vtkObject. AddObserver(), besides requiring an event id or name, also takes an instance of vtkCommand (or a subclasses). Note that vtkCommand is meant to be subclassed, so that you can package the information necessary to support your callback.
Event processing can be organized in priority lists, so it is possible to truncate the processing of a particular event by setting the AbortFlag variable. The priority is set using the AddObserver() method. By default the priority is 0, events of the same priority are processed in last-in-first-processed order. The ordering/aborting of events is important for things like 3D widgets, which handle an event if the widget is selected (and then aborting further processing of that event). Otherwise. the event is passed along for further processing.
When an instance of vtkObject invokes an event, it also passes an optional void pointer to a callData. This callData is NULL most of the time. The callData is not specific to a type of event but specific to a type of vtkObject invoking a specific event. For instance, vtkCommand::PickEvent is invoked by vtkProp with a NULL callData but is invoked by vtkInteractorStyleImage with a pointer to the vtkInteractorStyleImage object itself.
Here is the list of events that may be invoked with a non-NULL callData.
- vtkCommand::ProgressEvent
- most of the objects return a pointer to a double value ranged between 0.0 and 1.0
- Infovis/vtkFixedWidthTextReader returns a pointer to a float value equal to the number of lines read so far.
- vtkCommand::ErrorEvent
- an error message as a const char * string
- vtkCommand::WarningEvent
- a warning message as a const char * string
- vtkCommand::StartAnimationCueEvent
- a pointer to a vtkAnimationCue::AnimationCueInfo object
- vtkCommand::EndAnimationCueEvent
- a pointer to a vtkAnimationCue::AnimationCueInfo object
- vtkCommand::AnimationCueTickEvent
- a pointer to a vtkAnimationCue::AnimationCueInfo object
- vtkCommand::PickEvent
- Common/vtkProp returns NULL
- Rendering/vtkInteractorStyleImage returns a pointer to itself
- vtkCommand::StartPickEvent
- Rendering/vtkPropPicker returns NULL
- Rendering/vtkInteractorStyleImage returns a pointer to itself
- vtkCommand::EndPickEvent
- Rendering/vtkPropPicker returns NULL
- Rendering/vtkInteractorStyleImage returns a pointer to itself
- vtkCommand::WrongTagEvent
- Parallel/vtkSocketCommunicator returns a received tag as a char *
- vtkCommand::SelectionChangedEvent
- Views/vtkView returns NULL
- Views/vtkDataRepresentation returns a pointer to a vtkSelection
- Rendering/vtkInteractorStyleRubberBand2D returns an array of 5 unsigned integers (p1x, p1y, p2x, p2y, mode), where mode is vtkInteractorStyleRubberBand2D::SELECT_UNION or vtkInteractorStyleRubberBand2D::SELECT_NORMAL
- vtkCommand::AnnotationChangedEvent
- GUISupport/Qt/vtkQtAnnotationView returns a pointer to a vtkAnnotationLayers
- vtkCommand::PlacePointEvent
- Widgets/vtkSeedWidget returns a pointer to an int, being the current handle number
- vtkCommand::ResetWindowLevelEvent
- Widgets/vtkImagePlaneWidget returns an array of 2 double values (window and level)
- Rendering/vtkInteractorStyleImage returns a pointer to itself
- vtkCommand::StartWindowLevelEvent
- Widgets/vtkImagePlaneWidget returns an array of 2 double values (window and level)
- Rendering/vtkInteractorStyleImage returns a pointer to itself
- vtkCommand::EndWindowLevelEvent
- Widgets/vtkImagePlaneWidget returns an array of 2 double values (window and level)
- Rendering/vtkInteractorStyleImage returns a pointer to itself
- vtkCommand::WindowLevelEvent
- Widgets/vtkImagePlaneWidget returns an array of 2 double values (window and level)
- Rendering/vtkInteractorStyleImage returns a pointer to itself
- vtkCommand::CharEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QKeyEvent *
- vtkCommand::TimerEvent
- most of the objects return a to an int representing a timer id
- Rendering/vtkXRenderWindowTclInteractor returns NULL
- Widgets/vtkHoverWidget returns NULL
- vtkCommand::CreateTimerEvent
- Rendering/vtkGenericRenderWindowInteractor returns a to an int representing a timer id
- vtkCommand::DestroyTimerEvent
- Rendering/vtkGenericRenderWindowInteractor returns a to an int representing a timer id
- vtkCommand::UserEvent
- most of the objects return NULL
- Infovis/vtkInteractorStyleTreeMapHover returns a pointer to a vtkIdType representing a pedigree id
- vtkCommand::KeyPressEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QKeyEvent*
- vtkCommand::KeyReleaseEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QKeyEvent*
- vtkCommand::LeftButtonPressEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QMouseEvent*
- vtkCommand::LeftButtonReleaseEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QMouseEvent*
- vtkCommand::MouseMoveEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QMouseEvent*
- vtkCommand::MouseWheelForwardEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QWheelEvent*
- vtkCommand::MouseWheelBackwardEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QWheelEvent*
- vtkCommand::RightButtonPressEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QMouseEvent*
- vtkCommand::RightButtonReleaseEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QMouseEvent*
- vtkCommand::MiddleButtonPressEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QMouseEvent*
- vtkCommand::MiddleButtonReleaseEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QMouseEvent*
- vtkCommand::CursorChangedEvent
- most of the objects return a pointer to an int representing a shape
- Rendering/vtkInteractorObserver returns NULL
- vtkCommand::ResetCameraEvent
- Rendering/vtkRenderer returns a pointer to itself
- vtkCommand::ResetCameraClippingRangeEvent
- Rendering/vtkRenderer returns a pointer to itself
- vtkCommand::ActiveCameraEvent
- Rendering/vtkRenderer returns a pointer to the active camera
- vtkCommand::CreateCameraEvent
- Rendering/vtkRenderer returns a pointer to the created camera
- vtkCommand::EnterEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QEvent*
- vtkCommand::LeaveEvent
- most of the objects return NULL
- GUISupport/Qt/QVTKWidget returns a QEvent*
- vtkCommand::RenderWindowMessageEvent
- Rendering/vtkWin32OpenGLRenderWindow return a pointer to a UINT message
- vtkCommand::ComputeVisiblePropBoundsEvent
- Rendering/vtkRenderer returns a pointer to itself
- QVTKWidget::ContextMenuEvent
- GUISupport/Qt/QVTKWidget returns a QContextMenuEvent*
- QVTKWidget::DragEnterEvent
- GUISupport/Qt/QVTKWidget returns a QDragEnterEvent*
- QVTKWidget::DragMoveEvent
- GUISupport/Qt/QVTKWidget returns a QDragMoveEvent*
- QVTKWidget::DragLeaveEvent
- GUISupport/Qt/QVTKWidget returns a QDragLeaveEvent*
- QVTKWidget::DropEvent
- GUISupport/Qt/QVTKWidget returns a QDropEvent*
- vtkCommand::ViewProgressEvent
- View/vtkView returns a ViewProgressEventCallData*
- vtkCommand::VolumeMapperRenderProgressEvent
- A pointer to a double value between 0.0 and 1.0
- vtkCommand::VolumeMapperComputeGradientsProgressEvent
- A pointer to a double value between 0.0 and 1.0
- vtkCommand::TDxMotionEvent (TDx=3DConnexion)
- A vtkTDxMotionEventInfo*
- vtkCommand::TDxButtonPressEvent
- A int* being the number of the button
- vtkCommand::TDxButtonReleaseEvent
- A int* being the number of the button
- vtkCommand::UpdateShaderEvent
- A vtkOpenGLHelper* currently being used
关于tkCommand的各种事件的解释的更多相关文章
- cocos2d-x 3.0 touch事件官方解释
官方解释 http://www.cocos2d-x.org/docs/manual/framework/native/input/event-dispatcher/zh#_1
- Android ViewGroup拦截触摸事件具体解释
前言 在自己定义ViewGroup中.有时候须要实现触摸事件拦截.比方ListView下拉刷新就是典型的触摸事件拦截的样例. 触摸事件拦截就是在触摸事件被parent view拦截,而不会分发给其ch ...
- .NET 开源工作流: Slickflow流程引擎高级开发(九) -- 条件事件模式解释及应用
前言:在流程流转过程中,有时候需要条件模式的支持,这样可以使得流程流转更加灵活多变.比如在业务变量满足一定的条件时,可以启动特定配置的流程(或者位于主流程内部的子流程).本文主要描述条件启动和条件中间 ...
- 关于vtkCommand的各种事件的解释
superclass for callback/observer methods vtkCommand is an implementation of the observer/command des ...
- 读w3c中文教程对键盘事件解释的感想 -遁地龙卷风
写这篇博文源于w3c中文教程对键盘事件的解释, onkeydown 某个键盘按键被按下 onkeypress 某个键盘按键被按下并松开 onkeyup 某个键盘按键被松开 可在实践中发现 只注册key ...
- JS 预解释相关理解
1.JS中的内存空间分为两种:栈内存.堆内存 栈内存:提供JS代码执行的环境;存储基本数据类型的值; ->全局作用域或者私有的作用域其实都是栈内存 堆内存:存储引用数据类型的值(对象是把属性名和 ...
- jquery实现拖拽以及jquery监听事件的写法
很久之前写了一个jquery3D楼盘在线选择,这么一个插件,插件很简单,因为后期项目中没有实际用到,因此,有些地方不是很完善,后面也懒得再进行修改维护了.最近放到github上面,但是也少有人问津及s ...
- Android学习第六弹之Touch事件的处理
在移动开发过程当中,我们经常会遇到手势处理和事件触摸的情况,如果不了解整个事件的处理机制,对于开发的同学和码农是非常痛苦的,但是事件触摸的处理确实是一个非常复杂的过程,细讲起来,估计我都能讲迷糊,这里 ...
- GridView事件DataBinding,DataBound,RowCreated,RowDataBound区别及执行顺序分析
严格的说,DataBinding,DataBound并不是GridView特有的事件,其他的控件诸如ListBox等也有DataBinding,DataBound事件. DataBinding事件MS ...
随机推荐
- problems during rovio build
1. rovio的readme中使用的是catkin build, ROS tutorial中用的是catkin_make. 关于build与make的区别: build重新编译所有文件:make默认 ...
- 【linux】free命令中cached和buffers的区别
一.命令 [root@localhost ~]# free -m total used free shared buffers cached Mem: 7869 7651 218 1 191 5081 ...
- 基于英特尔® 至强™ 处理器 E5 产品家族的多节点分布式内存系统上的 Caffe* 培训
原文链接 深度神经网络 (DNN) 培训属于计算密集型项目,需要在现代计算平台上花费数日或数周的时间方可完成. 在最近的一篇文章<基于英特尔® 至强™ E5 产品家族的单节点 Caffe 评分和 ...
- Ioc和Ao使用扩展
一.Bean作用域 spring容器创建的时候,会将所有配置的bean对象创建出来,默认bean都是单例的.代码通过getBean()方法从容器获取指定的bean实例,容器首先会调用Bean类的无参构 ...
- java的会话管理:Cookie和Session
java的会话管理:Cookie和Session 1.什么是会话 此处的是指客户端(浏览器)和服务端之间的数据传输.例如用户登录,购物车等 会话管理就是管理浏览器客户端和服务端之间会话过程产生的会话数 ...
- 学习python函数笔记之一
1.函数文档字符串,用于存放函数的说明,一般写在第一行 2.函数调用:函数名+参数列表(函数的参数分实际参数和形式参数,str就是形式参数,则'welcome 头 python'就是实际参数) 参数需 ...
- codevs 1080 线段树点修改
先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...
- ngx_http_fastcgi_module模块.md
ngx_http_fastcgi_module ngx_http_fastcgi_module模块允许将请求传递到FastCGI服务器. fastcgi_bind Syntax: fastcgi_bi ...
- django ORM的外键操作
外键约束示例 #models操作如下 class HostInfo(models.Model): servername = models.CharField(max_length=) serverip ...
- [LeetCode] Sort List 链表排序
Sort a linked list in O(n log n) time using constant space complexity. 常见排序方法有很多,插入排序,选择排序,堆排序,快速排序, ...