Effacer les filtres
Effacer les filtres

timer not always running

1 vue (au cours des 30 derniers jours)
Jim Hokanson
Jim Hokanson le 22 Oct 2014
Modifié(e) : per isakson le 12 Juin 2015
I have an event listener callback. In that callback I run the following code:
disp('I ran')
t = obj.timer; %obj is instance of handle class
stop(t);
set(t,'TimerFcn',@(~,~)obj.resize2(h,event_data,axes_I,count,new_xlim,new_position));
start(t)
obj.timer = t; %Hold onto new timer so that it doesn't get deleted and executes
In resize2():
disp('I ran too!')
Previously I've done: t = timer; t.StartDelay = TIMER_START_DELAY; obj.timer = t;
I'm seeing code that indicates that the callback ran, but not the resize2() function. I'm seeing something like:
I ran
I ran
I ran
I ran
I ran too
I ran
I ran
I ran too
I ran
I ran
The way the callback code is setup, I want there always to be at least one call to resize2, following any calls to the callback. Any thoughts on why I am not seeing this?
Thanks, Jim
  3 commentaires
Jim Hokanson
Jim Hokanson le 23 Oct 2014
Modifié(e) : per isakson le 12 Juin 2015
Hi Geoff,
Thanks for the great questions! I'm using a different approach now and my problem has gone away, but I'm still curious as to why I see this problem.
To answer your questions. I have a process that takes a long(ish) time to run. The callback is being executed many times. I don't want to execute every callback, because this would take a potentially long time.
Alternatively, I could check if I am currently executing a callback, and ignore the calls to resize2. This is being done in some other code on the FEX, but it also means that I won't always run the latest callback. If I could drop callbacks, I'd rather drop earlier ones than later ones.
To drop earlier calls, and not later calls, I am using the timer approach. Every time the callback executes, I am essentially telling the timer (I think) - "wait a little bit longer until running"
Each "I ran too" should correspond with the last "I ran" statement - so the first "I ran too" should correspond with the 4th "I ran" statement.
Oops, I also noticed some abbreviations to the code that make all of this not-obvious. I've added some code above to make it obvious that I'm holding onto the timers between calls.
Make sense? Any insights or suggestions?
Thanks, Jim
Geoff Hayes
Geoff Hayes le 24 Oct 2014
Hi Jim - That's an interesting approach which makes sense. I still wonder about the properties for your timer - how is it initialized (period, etc.)?

Connectez-vous pour commenter.

Réponses (0)

Catégories

En savoir plus sur Graphics Object Programming dans Help Center et File Exchange

Tags

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by