Thanks,

That works!

The behaviour does seem slightly strange though - I would expect the JS 
function to complete and THEN have everything else updated, but as long as I 
know that this is the current behaviour I can create code accordingly.

Thanks again

Mark

-----Original Message-----
From: Adriano Rezende [mailto:adriano.reze...@openbossa.org] 
Sent: 07 December 2010 19:16
To: Mark Tucker
Cc: qt-qml@trolltech.com
Subject: Re: [Qt-qml] Error with PropertyAction/SequentialAnimation/Timer

On Tue, Dec 7, 2010 at 12:59 PM, Mark Tucker <mark.tuc...@airborne.aero> wrote:
>        Timer {
>                id: textTimer
>                interval: 5000
>                repeat: true
>                running: true
>                triggeredOnStart: true
>                onTriggered: {
>                        listIndex++;
>                        if (listIndex >= model.count) {
>                                listIndex = 0;
>                        }
>                        //console.log("listIndex: " + listIndex + "
> count: " + model.count)
>                        textAnimation.start();
>                }
>        }
> }
> For some reason the PropertyAction is being called when listIndex is 3
> and hence causes an error due to an undefined value. I'm failing to see
> how it should ever be the case that listIndex should be 3 when the
> PropertyAction does its thing though.

I believe QML will reevaluate a JS statement each time you change a
bindable property contained in that statement. So, even if the
animation is not running, "model.get(listIndex).dataString" will be
reevaluated when listIndex changes.
So, in order to solve this problem you can change the code below:

> listIndex++;
> if (listIndex >= model.count) {
>     listIndex = 0;
> }

for the following:

listIndex = (listIndex + 1) % model.count;

Br,
Adriano

_______________________________________________
Qt-qml mailing list
Qt-qml@trolltech.com
http://lists.trolltech.com/mailman/listinfo/qt-qml

Reply via email to