Retired Document
Important: This sample code may not represent best practices for current development. The project may use deprecated symbols and illustrate technologies and techniques that are no longer recommended.
Fortune.wdgt/Fortune.js
/* |
File: Fortune.js |
Abstract: JavaScript logic for Fortune widget plug-in sample |
Version: 1.0 |
© Copyright 2005 Apple Computer, Inc. All rights reserved. |
IMPORTANT: This Apple software is supplied to |
you by Apple Computer, Inc. ("Apple") in |
consideration of your agreement to the following |
terms, and your use, installation, modification |
or redistribution of this Apple software |
constitutes acceptance of these terms. If you do |
not agree with these terms, please do not use, |
install, modify or redistribute this Apple |
software. |
In consideration of your agreement to abide by |
the following terms, and subject to these terms, |
Apple grants you a personal, non-exclusive |
license, under Apple's copyrights in this |
original Apple software (the "Apple Software"), |
to use, reproduce, modify and redistribute the |
Apple Software, with or without modifications, in |
source and/or binary forms; provided that if you |
redistribute the Apple Software in its entirety |
and without modifications, you must retain this |
notice and the following text and disclaimers in |
all such redistributions of the Apple Software. |
Neither the name, trademarks, service marks or |
logos of Apple Computer, Inc. may be used to |
endorse or promote products derived from the |
Apple Software without specific prior written |
permission from Apple. Except as expressly |
stated in this notice, no other rights or |
licenses, express or implied, are granted by |
Apple herein, including but not limited to any |
patent rights that may be infringed by your |
derivative works or by other works in which the |
Apple Software may be incorporated. |
The Apple Software is provided by Apple on an "AS |
IS" basis. APPLE MAKES NO WARRANTIES, EXPRESS OR |
IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED |
WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY |
AND FITNESS FOR A PARTICULAR PURPOSE, REGARDING |
THE APPLE SOFTWARE OR ITS USE AND OPERATION ALONE |
OR IN COMBINATION WITH YOUR PRODUCTS. |
IN NO EVENT SHALL APPLE BE LIABLE FOR ANY |
SPECIAL, INDIRECT, INCIDENTAL OR CONSEQUENTIAL |
DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS |
OF USE, DATA, OR PROFITS; OR BUSINESS |
INTERRUPTION) ARISING IN ANY WAY OUT OF THE USE, |
REPRODUCTION, MODIFICATION AND/OR DISTRIBUTION OF |
THE APPLE SOFTWARE, HOWEVER CAUSED AND WHETHER |
UNDER THEORY OF CONTRACT, TORT (INCLUDING |
NEGLIGENCE), STRICT LIABILITY OR OTHERWISE, EVEN |
IF APPLE HAS BEEN ADVISED OF THE POSSIBILITY OF |
SUCH DAMAGE. |
*/ |
/**************************/ |
// Fortune-specific code |
// This code drives the Fortune widget |
/**************************/ |
// swap |
// |
// Swaps out the current fortune for a new one. Uses the Obj-C/JavaScript widget |
// plugin to get the new fortune. |
function swap() { |
if (FortunePlugin) { |
var line = FortunePlugin.getFortune(); // get a fortune from the widget plugin |
document.getElementById("quote").innerHTML = line; // drop in the new fortune |
} |
else { |
alert("Widget plugin not loaded."); |
} |
} |
// next |
// |
// Performs the transition from the current fortune to the next one. |
function next() |
{ |
hideContent(); // fades out the current fortune |
setTimeout("swap();",500); // swaps in the new fortune |
setTimeout("showContent();",550); // fades in the new fortune |
} |
/**************************/ |
// Animation code |
// Handles the fades in and out |
/**************************/ |
var animation = {duration:0, starttime:0, to:1.0, now:1.0, from:0.0, firstElement:null, timer:null}; |
function showContent() |
{ |
if (animation.timer != null) // reset the animation timer value, in case a value was left behind |
{ |
clearInterval (animation.timer); |
animation.timer = null; |
} |
var starttime = (new Date).getTime() - 13; // set it back one frame |
animation.duration = 500; // animation time, in ms |
animation.starttime = starttime; // specify the start time |
animation.firstElement = document.getElementById ('quote'); // specify the element to fade |
animation.timer = setInterval ("animate();", 13); // set the animation function |
animation.from = animation.now; // beginning opacity (not ness. 0) |
animation.to = 1.0; // final opacity |
animate(); // begin animation |
} |
function hideContent() |
{ |
if (animation.timer != null) |
{ |
clearInterval (animation.timer); |
animation.timer = null; |
} |
var starttime = (new Date).getTime() - 13; |
animation.duration = 500; |
animation.starttime = starttime; |
animation.firstElement = document.getElementById ('quote'); |
animation.timer = setInterval ("animate();", 13); |
animation.from = animation.now; |
animation.to = 0.0; |
animate(); |
} |
function animate() |
{ |
var T; |
var ease; |
var time = (new Date).getTime(); |
T = limit_3(time-animation.starttime, 0, animation.duration); |
if (T >= animation.duration) |
{ |
clearInterval (animation.timer); |
animation.timer = null; |
animation.now = animation.to; |
} |
else |
{ |
ease = 0.5 - (0.5 * Math.cos(Math.PI * T / animation.duration)); |
animation.now = computeNextFloat (animation.from, animation.to, ease); |
} |
animation.firstElement.style.opacity = animation.now; |
} |
// these functions are utilities used by animate() |
function limit_3 (a, b, c) |
{ |
return a < b ? b : (a > c ? c : a); |
} |
function computeNextFloat (from, to, ease) |
{ |
return from + (to - from) * ease; |
} |
Copyright © 2005 Apple Computer, Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2005-06-01