glutIdleFunc设置全局的
回调函数,当没有窗口事件到达时,
GLUT程序功能可以执行后台处理任务或连续动画。如果启用,这个idle function会被不断调用,直到有窗口事件发生。回调函数没有参数。当前的窗口和菜单在执行idle func之前不会改变。当程序依赖多窗口或菜单时最好不要依赖于当前设定。
void glutIdleFunc(void (*func)(
void));
glutIdleFunc sets the global idle callback to be func so a GLUT program can perform background processing tasks or continuous animation when window system events are not being received. If enabled, the idle callback is continuously called when events are not being received. The callback routine has no parameters. Thecurrent windowandcurrent menuwill not be changed before the idle callback. Programs with multiple windows and/or menus should explicitly set thecurrent windowand/orcurrent menuand not rely on its current setting.
The amount of computation and rendering done in an idle callback should be minimized to avoid affecting the program's interactive response. In general, not more than a single frame of rendering should be done in an idle callback.
assing NULL to glutIdleFunc disables the generation of the idle callback.
应尽量减少在空闲
回调完成的计算和渲染的数额,以避免影响程序的交互响应。在一般情况下,不超过单帧的渲染工作应在一个空闲回调。
在glutIdleFunc(void (*func)(
void))
回调函数中指定一个函数,如果不存在其他尚未完成的事件(例如,当事件循环处于空闲的时候),就执行这个函数。这个回调函数接受一个
函数指针作为它的唯一参数。如果向它传递NULL(0),就相当于禁用这个函数。