Today I wanted to further rearrange the transition definitions so they more closely matched those used by the Greensock animation product I’ve been emulating. A screenshot from their demo video is shown here:
The next step is to move the duration parameter to be the second term in the addTransformToList
function call(s) as shown here:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
var handle001 = document.getElementById("handle001"); bcInitElement(handle001,"301px","50px","red","rgba(0,0,0,0)","260px",0,"block","This line slides in, out, in"); addTransformToList("handle001",0.75,{left:-284, opacity:1.0},0.00,"linear"); addTransformToList("handle001",0.50,{left:284},0.75,"linear"); addTransformToList("handle001",0.75,{left:-284},1.25,"linear"); addTransformToList("handle001",0.00,{display:"none"},2.00,""); var handle002 = document.getElementById("handle002"); bcInitElement(handle002,"17px","-25px","blue","rgba(0,0,0,0)","280px",0,"block","This line drops down from the top"); addTransformToList("handle002",0.75,{top:150, opacity:1.0},0.50,"linear"); addTransformToList("handle002",0.00,{display:"none"},2.00,""); var handle003 = document.getElementById("handle003"); bcInitElement(handle003,"120px","60px","yellow","rgba(0,0,0,0)","80px",0,"block","This text grows in scale"); handle003.style.transform = "scale(0.5,0.5)"; addTransformToList("handle003",0.05,{opacity:1.0},1.95,"linear"); addTransformToList("handle003",1.50,{scale:"(2.0,2.0)"},2.50,"linear"); |
The next step is to get rid of the direct specification of the starting time in this call (currently the fourth parameter as shown above). In theory it would be a simple matter to track the cumulative starting times of the transforms from the delays (as they are specified in order) and use that information to replace the starting time parameter. I’m also going to add an adjustment factor that will allow the user to specify a bump forward or backward in time relative to where the starting time would have been. That’ll be handled with an optional item at the end of the parameter list.
The adjustment factor can be absolute, say, 0.25 seconds earlier than the default (the end of the previous transform), as shown in the second line of the Greensock demo image, above. Easy enough, right? Well, we also want to be able to specify a different basis for an offset, one that isn’t blindly based on the previous element but one that is referred to by its label. That should be simple enough–but what if the label is found in the list of transforms more than once? The Greensock demo doesn’t show a case where that happens but my scenario does. I think the tool should be able to handle that circumstance so I’m going to have to add in my own twist on things. I’m going to make the code handle labels with and additional specifier, separated from the label by a colon.
Let’s start by reviewing what we have so far.
Since the first four items are specified in order they could probably be left alone. However, transform 5, the first transform for the second element, starts before the end of transform 1, the first transform for the first element. Similarly, transform 7, the first transform for the third element, also happens before several of the other transforms complete. Indeed, there are three transforms that all end at the same time. We therefore need a way not only to refer to a transform by name, but also by which occurrence of that name.
There’s one more bit of complexity: how do we handle the cumulative starting time of transforms if they are specified in unexpected ways? The first four items in the above example are straightforward. They go in order, without delays, and each advances the accumulated start timer. Transform 5 has to be offset from the end of transform 1, and it won’t advance the timer. Transform 6 has to be based on transform 4 (or the end of transform 3, in theory). Transform 7 could be based on transforms 3, 4, or 6. Transform 8, finally, could be based on transforms 3, 4, 6, or 7.
Leave it to me to make things complicated, right?
I think what I’m going to do, since it would be most comprehensible to the user, is to base everything on transform 3, with the exception of transform 5, which has to be based on transform 1. That code would, in theory, look like this:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
var handle001 = document.getElementById("handle001"); bcInitElement(handle001,"301px","50px","red","rgba(0,0,0,0)","260px",0,"block","This line slides in, out, in"); addTransformToList("handle001:1",0.75,{left:-284, opacity:1.0},"linear"); //starts at 0.00 addTransformToList("handle001",0.50,{left:284},"linear"); //starts at 0.75 addTransformToList("handle001:2",0.75,{left:-284},"linear"); //starts at 1.25 addTransformToList("handle001",0.00,{display:"none"},""); //starts at 2.00 var handle002 = document.getElementById("handle002"); bcInitElement(handle002,"17px","-25px","blue","rgba(0,0,0,0)","280px",0,"block","This line drops down from the top"); addTransformToList("handle002",0.75,{top:150, opacity:1.0},"linear","handle001:1-=0.25"); //starts at 0.50 addTransformToList("handle002",0.00,{display:"none"},"","handle001:2"); //starts at 2.00 var handle003 = document.getElementById("handle003"); bcInitElement(handle003,"120px","60px","yellow","rgba(0,0,0,0)","80px",0,"block","This text grows in scale"); handle003.style.transform = "scale(0.5,0.5)"; addTransformToList("handle003",0.05,{opacity:1.0},"linear","handle001:2-=0.05"); //starts at 1.95 addTransformToList("handle003",1.50,{scale:"(2.0,2.0)"},"linear","+=0.50"); //starts at 2.50 |
I originally saw that this case doesn’t allow for specifying a simple offset from the previous element (like the second transform in the Greensock demo), so I changed transform 8 to start with an offset directly from transform 7. What I have to decide now is whether to maintain a single, global start time accumulator or allow items with like handles to maintain their own, local start time accumulator. I think the former, but we shall see.
So what do I have here? Again, the first four are easy, as is transform 6. Transform 8 is now easy-ish because we are least have a straightforward place to start from. Transforms 5 and 7 combine both a reference to not only a label, but a complex label, and also an offset.
This completes the analysis, tomorrow we’ll tackle the code.