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
  • vtkCommand::EndAnimationCueEvent
  • vtkCommand::AnimationCueTickEvent
  • 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
  • vtkCommand::AnnotationChangedEvent
  • 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的各种事件的解释的更多相关文章

  1. cocos2d-x 3.0 touch事件官方解释

    官方解释 http://www.cocos2d-x.org/docs/manual/framework/native/input/event-dispatcher/zh#_1

  2. Android ViewGroup拦截触摸事件具体解释

    前言 在自己定义ViewGroup中.有时候须要实现触摸事件拦截.比方ListView下拉刷新就是典型的触摸事件拦截的样例. 触摸事件拦截就是在触摸事件被parent view拦截,而不会分发给其ch ...

  3. .NET 开源工作流: Slickflow流程引擎高级开发(九) -- 条件事件模式解释及应用

    前言:在流程流转过程中,有时候需要条件模式的支持,这样可以使得流程流转更加灵活多变.比如在业务变量满足一定的条件时,可以启动特定配置的流程(或者位于主流程内部的子流程).本文主要描述条件启动和条件中间 ...

  4. 关于vtkCommand的各种事件的解释

    superclass for callback/observer methods vtkCommand is an implementation of the observer/command des ...

  5. 读w3c中文教程对键盘事件解释的感想 -遁地龙卷风

    写这篇博文源于w3c中文教程对键盘事件的解释, onkeydown 某个键盘按键被按下 onkeypress 某个键盘按键被按下并松开 onkeyup 某个键盘按键被松开 可在实践中发现 只注册key ...

  6. JS 预解释相关理解

    1.JS中的内存空间分为两种:栈内存.堆内存 栈内存:提供JS代码执行的环境;存储基本数据类型的值; ->全局作用域或者私有的作用域其实都是栈内存 堆内存:存储引用数据类型的值(对象是把属性名和 ...

  7. jquery实现拖拽以及jquery监听事件的写法

    很久之前写了一个jquery3D楼盘在线选择,这么一个插件,插件很简单,因为后期项目中没有实际用到,因此,有些地方不是很完善,后面也懒得再进行修改维护了.最近放到github上面,但是也少有人问津及s ...

  8. Android学习第六弹之Touch事件的处理

    在移动开发过程当中,我们经常会遇到手势处理和事件触摸的情况,如果不了解整个事件的处理机制,对于开发的同学和码农是非常痛苦的,但是事件触摸的处理确实是一个非常复杂的过程,细讲起来,估计我都能讲迷糊,这里 ...

  9. GridView事件DataBinding,DataBound,RowCreated,RowDataBound区别及执行顺序分析

    严格的说,DataBinding,DataBound并不是GridView特有的事件,其他的控件诸如ListBox等也有DataBinding,DataBound事件. DataBinding事件MS ...

随机推荐

  1. ubuntu系统安装初始化脚本

    ubuntu系统安装初始化脚本 经常安装卸载ubuntu,每次系统安装完成后要安装好多软件,一个个命令输很麻烦浪费时间,一个sh文件全搞定! 1. flashplayer下载:点击这里 2. Auda ...

  2. HTTP状态码(HTTP Status Code)

    一些常见的状态码为: 200 - 服务器成功返回网页 404 - 请求的网页不存在 503 - 服务不可用 所有状态解释: 1xx(临时响应)表示临时响应并需要请求者继续执行操作的状态代码. 代码 说 ...

  3. Java并发包源码分析

    并发是一种能并行运行多个程序或并行运行一个程序中多个部分的能力.如果程序中一个耗时的任务能以异步或并行的方式运行,那么整个程序的吞吐量和可交互性将大大改善.现代的PC都有多个CPU或一个CPU中有多个 ...

  4. Hbase学习连接-数据导入

    http://www.csdn.net/article/2014-01-07/2818046

  5. JavaScript模板引擎artTemplate.js——template.helper()方法

    上一篇文章我们已经讲到了helper()方法,但是上面的例子只是一个参数的写法,如果是多个参数,写法就另有区别了. <div id="user_info"></d ...

  6. 神奇的BFC以及被忽略的东西

    BFC是CSS中一个非常重要的概念,经常用来清除浮动以及处理外边距折叠,但BFC到底是个什么东西却很难准确的表达清楚,国内的相关技术文档基本都不全面,本文的目的就是对BFC的方方面面做个整理,当然未必 ...

  7. 详解C#中的反射

    反射(Reflection) 2008年01月02日 星期三 11:21 两个现实中的例子:1.B超:大家体检的时候大概都做过B超吧,B超可以透过肚皮探测到你内脏的生理情况.这是如何做到的呢?B超是B ...

  8. vs2017 rc 离线安装包制作

    vs2017 rc 离线安装包制作 1.下载在线安装包:https://aka.ms/vs/15/release/vs_Enterprise.exe 2.制作离线安装包: vs_Enterprise. ...

  9. geolocation/ 百度地图api Geolocation 定位当前城市信息

    根据当前所处位置 定位所在城市信息 <html> <head> <meta charset="UTF-8" /> <title>js ...

  10. supervisor的安装与简单介绍

    1,介绍 Supervisor是一个进程管理工具,官方的说法 用途就是有一个进程需要每时每刻不断的跑,但是这个进程又有可能由于各种原因有可能中断.当进程中断的时候我希望能自动重新启动它,此时,我就需要 ...