1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
|
#include <iostream>
#include <thread>
#include <pcl/common/time_trigger.h>
#include <pcl/common/time.h>
using namespace std::chrono_literals;
using namespace pcl;
double global_time;
void callback ()
{
static double last_time = pcl::getTime ();
double elapsed = pcl::getTime () - last_time;
last_time = pcl::getTime ();
std::cout << "global fn: " << pcl::getTime () - global_time << " :: " << elapsed << std::endl;
std::this_thread::sleep_for(1ms);
}
class Dummy
{
public:
void myTimer ()
{
static double last_time = pcl::getTime ();
double elapsed = pcl::getTime () - last_time;
last_time = pcl::getTime ();
std::cout << "member fn: " << pcl::getTime () - global_time << " :: " << elapsed << std::endl;
}
};
int main ()
{
TimeTrigger trigger (10.0, callback);
Dummy dummy;
global_time = pcl::getTime ();
trigger.start ();
std::this_thread::sleep_for(2s);
trigger.registerCallback ([&]{ dummy.myTimer (); });
std::this_thread::sleep_for(3s);
trigger.setInterval (0.2);
std::this_thread::sleep_for(2s);
return 0;
}
|