Clutter学习(九):Timeline的时间和帧触发

  学习资料来源:Using TimelinesMarkersExamples

  使用方法如下:
一、创建一个CLutterTimeline的类型,clutter_timeline_new()
二、设置监测事件。
三、启动clutter_timeline_start(),停止clutter_timeline_stop(),循环clutter_timeline_set_loop()

  我觉得ClutterTimeline是个很好的类型,会在Clutter项目中经常使用。他提供了两种触发机制。第一种是“newframe”,在其他的图形开发中,如果我们需要动态处理图像变化,可能需要一个timeout时间,在这个时间到了的时间,redraw画面,Clutter提供了很特别的一种方式,在屏幕帧刷新的时候触发“newframe”事件。需要注意的是,不同monitor,刷新频率是不一样的,newframe的触发不同机器的时间间隔是不一样的,如果需要各类机器获得同样的效果,需要加上timestampe了进行计算,无论如何,可以使图像在最小的颗粒度内进行重画,已达到最佳的平滑效果。


  另一个是我们自行定义的marker-reached,这是基于时间触发的。下面的图说明ClutterTimeline的触发机制。在创建ClutterTimeline,我定义时间为T0,也就是T0时间为一个timeout时间,如果我们通过clutter_timeline_set_loop()定义循环,那么在T0结束后开启一个新的T0时间片,知道程序结束或者通过clutter_timeline_stop()来结束循环。我们可以在每个时间片中,通过clutter_timeline_add_marker_at_time,设置timeout时钟,触发事件为marker-reached。

  下面是小例子。我们将一个方框进行旋转已经颜色的alpha变化。

#include <clutter/clutter.h>
#include <stdlib.h>
#include <time.h>

long offset = 0;
long get_time(){
    return time(0)-offset;
}

int alpha = 0x99;

/* 刷屏的触发函数*/
void on_timeline_new_frame(ClutterTimeline * timeline, gint frame_num, gpointer data){
    static int tag = 1;
    static float step = 0;

    /*每次刷屏,转动1度*/
    step +=1.0;
    if(step >= 360)
        step = 0;
    clutter_actor_set_rotation((ClutterActor *) data,CLUTTER_X_AXIS,step,0,0,0);

    /*颜色由亮到暗,由暗到亮,循环变化*/

    if(tag == 1){
        alpha ++;
        if(alpha >= 0xef)
            tag = 0;
    }else{
        alpha --;
        if(alpha <= 0x30)
            tag ++;
    }
    ClutterColor color = {0xff,0xff,0xff,alpha};
    clutter_rectangle_set_color(CLUTTER_RECTANGLE(data),&color);
}

/* 自定义的时间触发函数,可以作为时钟函数使用,而第三个参数,经过测试应是时间片中相对时间,单位为msec */
void on_timeline_marker_reached(ClutterTimeline * timeline,gchar * marker_name, gint num,  gpointer data){
    printf("%ld marker %s reached : frame-num = %d /n", get_time(),marker_name,num);
}

int main(int argc, char* argv[]){
    ClutterColor stage_color = {0x00,0x00,0x00,0xff};
    ClutterColor rect_color = {0xff,0xff,0xff,alpha};

    clutter_init(&argc,&argv);
   
    /*Clutter stage and rect*/
    ClutterActor *stage = clutter_stage_get_default();
    clutter_actor_set_size(stage,200,200);
    clutter_stage_set_color(CLUTTER_STAGE(stage), & stage_color);
    ClutterActor * rect = clutter_rectangle_new_with_color(&rect_color);
    clutter_actor_set_size(rect,70,70);
    clutter_actor_set_position(rect,50,100);
    clutter_container_add_actor(CLUTTER_CONTAINER(stage),rect);
    clutter_actor_show(rect);
    clutter_actor_show(stage);


    offset = time(0);

    /*Timeline部分,我们开启一个时间片为5秒(5000 msecs)的timeline,并创建一个时间名为“my-mark”的时间触发点,触发点位于每个时间片的第2000毫秒。接着启动更新帧的触发事件,以便我们进行动态处理,跟着设置时间触发点的触发,我们可以在一个时间片内设置0个或者多个时间触发点。最后设置为循环模式,并且启动它。*/
    ClutterTimeline * timeline = clutter_timeline_new (5000);
    clutter_timeline_add_marker_at_time (timeline, "my-mark",2000);
    g_signal_connect(timeline,"new-frame" , G_CALLBACK(on_timeline_new_frame),rect);
    g_signal_connect(timeline,"marker-reached" , G_CALLBACK(on_timeline_marker_reached),NULL);   
    clutter_timeline_set_loop (timeline,TRUE);
    clutter_timeline_start (timeline);

    clutter_main();

    g_object_unref(timeline);
    return EXIT_SUCCESS;
}

相关链接:
我的Clutter相关博客

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值