data:image/s3,"s3://crabby-images/f853c/f853cbf8051f33068e26510f9c12f1bbf43e5b43" alt=""
Description/
Hey Google, What did it take to get this project done?
This project had two aspects: To create content for preexisting displays throughout Las Vegas and to create a series of animations to be played 24 hours a day on a custom dual display at Google’s playground at CES. My first duty was to automate the query and response animations that were to be used throughout the project. Then, I was in charge of one of the larger displays with the most configuration of products being advertised. Finally, I flew out to Las Vegas with the BNS team to finalize and assure all 100+ animations were screen ready for the opening launch at CES.
This project had two aspects: To create content for preexisting displays throughout Las Vegas and to create a series of animations to be played 24 hours a day on a custom dual display at Google’s playground at CES. My first duty was to automate the query and response animations that were to be used throughout the project. Then, I was in charge of one of the larger displays with the most configuration of products being advertised. Finally, I flew out to Las Vegas with the BNS team to finalize and assure all 100+ animations were screen ready for the opening launch at CES.
Duties/
Animation, AE Automation, Project Manager of Animation
From Las Vegas in Situation/
Automation/
data:image/s3,"s3://crabby-images/cc861/cc8615b369f6b432c4ac5d4984fa6c5953adb6cc" alt=""
data:image/s3,"s3://crabby-images/b4a2f/b4a2f1e65e6ea055e5646eb0f1913b782ee81ad5" alt=""
Both query and response bubble size reacted dynamically to the length of text. The text itself also had a custom expression to allow it to write on with a slide controller in order to work with the bubble size expression. Olle Engström designed the animation for all the Google branding elements used in the project.
Expression/
Source text expression write on. (written by: Dan Ebberts)
s = effect("Slider Control")("Slider").value;
str = "";
txt = value.split(" ");
for (i = 0; i < Math.min(txt.length,s); i++){
str += (i > 0 ? " " : "") + txt[i];
}
Str
str = "";
txt = value.split(" ");
for (i = 0; i < Math.min(txt.length,s); i++){
str += (i > 0 ? " " : "") + txt[i];
}
Str
Photos from Event/
data:image/s3,"s3://crabby-images/1ce5f/1ce5fe085c46b49abf841c5c8e2f7e64e8b44371" alt=""
data:image/s3,"s3://crabby-images/b27ab/b27ab0b3a9ec9ff76992ab6a71daa9f73d6fc70f" alt=""
data:image/s3,"s3://crabby-images/06561/06561566abc048b7335fc905f20972b9cf288859" alt=""
data:image/s3,"s3://crabby-images/6d285/6d285881cc8ff4740c2e5e4d39fdbe1f82ae09cf" alt=""
data:image/s3,"s3://crabby-images/f2c32/f2c324efba2451d365a93ba6e5f60b22c6037d1b" alt=""
data:image/s3,"s3://crabby-images/ae7cc/ae7cc129b94e9ada5357f34eb35f16fa99c5e4f4" alt=""
data:image/s3,"s3://crabby-images/6e446/6e446d0bebd05704be5e73d719265215b7bba76a" alt=""
data:image/s3,"s3://crabby-images/fa9ba/fa9bae06e74c793ba31e53a02f416d4f08c8adc4" alt=""
data:image/s3,"s3://crabby-images/0d838/0d83826ffbdebdb7ea478428d618068388a79950" alt=""
data:image/s3,"s3://crabby-images/7024a/7024a83a9bb1922396c2392099ed3180bc3fa3af" alt=""
data:image/s3,"s3://crabby-images/bdafc/bdafc98afa527eefc0d349bc6a97d024228ac804" alt=""
data:image/s3,"s3://crabby-images/bbf70/bbf700051ebdddead7f9b719470c5b23e3d0ea4d" alt=""
data:image/s3,"s3://crabby-images/7e6d9/7e6d975f9efb17981a3b70ac43e35a12e30d8168" alt=""
data:image/s3,"s3://crabby-images/2f3d7/2f3d77ecf6b4ef67840d62fe1b814583f17eeba2" alt=""
data:image/s3,"s3://crabby-images/ab5a3/ab5a3f0d8a60fa77e14c439f6a427735ffe29e39" alt=""
Harmon Sqaure Display/
Breakdown & Build/
data:image/s3,"s3://crabby-images/6c957/6c95788a994dd4d900b7bfeb74c027ed5e9b5afa" alt=""
The Harmon animation was designed to be modular and was built within a dimensional grid that allowed itself to looped.
data:image/s3,"s3://crabby-images/8fb8f/8fb8f9b61f1a2ceefe6352eae958da22dc78e812" alt=""
data:image/s3,"s3://crabby-images/4cf8d/4cf8d4a7360226ab816532f8b904a727565b63f2" alt=""
An expression was used to automate all the products to reveal themselves based on the camera's location.
Expression/
Camera Z Distance, Layer Fade in and Out. (written by: Dan Ebberts)
fadeInStart = XXXX; // Connect to Slider
fadeInEnd = XXXX; // Connect to Slider
fadeOutStart = XXXX; // Connect to Slider
fadeOutEnd = XXXX; // Connect to Slider
C = thisComp.activeCamera; // Or connect to any camera in any comp
v1 = toWorld(anchorPoint) - C.toWorld([0,0,0]);
v2 = C.toWorldVec([0,0,1]);
d = dot(v1,v2);
if (d > fadeInEnd)
linear(d,fadeInEnd,fadeInStart,100,0)
else if (d > fadeOutStart)
100
else
linear(d,fadeOutEnd,fadeOutStart,0,100);
fadeInEnd = XXXX; // Connect to Slider
fadeOutStart = XXXX; // Connect to Slider
fadeOutEnd = XXXX; // Connect to Slider
C = thisComp.activeCamera; // Or connect to any camera in any comp
v1 = toWorld(anchorPoint) - C.toWorld([0,0,0]);
v2 = C.toWorldVec([0,0,1]);
d = dot(v1,v2);
if (d > fadeInEnd)
linear(d,fadeInEnd,fadeInStart,100,0)
else if (d > fadeOutStart)
100
else
linear(d,fadeOutEnd,fadeOutStart,0,100);
Fashion Show Display/
Andoid Auto/
Hey Google Animation/
data:image/s3,"s3://crabby-images/71822/7182252b916fcfaea45b390acbd6f89f82c4a486" alt=""
To make this animation easy to create and manage an expression was developed to scale the layer up and down within its on timeline length.
Expression/
Scale in and out based on layer's timeline length. (written by: Dan Ebberts)
cIn = thisComp.layer("Control_Scale_In").transform.scale; //Controler layer to scale in
dIn = cIn.key(cIn.numKeys).time - cIn.key(1).time;
cOut = thisComp.layer("Control_Scale_Out").transform.scale; //Controler layer to scale out
dOut = cOut.key(cOut.numKeys).time - cOut.key(1).time;
dIn = cIn.key(cIn.numKeys).time - cIn.key(1).time;
cOut = thisComp.layer("Control_Scale_Out").transform.scale; //Controler layer to scale out
dOut = cOut.key(cOut.numKeys).time - cOut.key(1).time;
if (time < inPoint+dIn){
cIn.valueAtTime(cIn.key(1).time + time - inPoint);
}else if (time < outPoint - dOut){
cOut.valueAtTime(cOut.key(1).time);
}else{
cOut.valueAtTime(cOut.key(cOut.numKeys).time - (outPoint - time));
}
cIn.valueAtTime(cIn.key(1).time + time - inPoint);
}else if (time < outPoint - dOut){
cOut.valueAtTime(cOut.key(1).time);
}else{
cOut.valueAtTime(cOut.key(cOut.numKeys).time - (outPoint - time));
}
Credits/
Creative Directors: Jonathan Notaro, Bucky Fukumoto, Mike Calvert
Designers: Jonathan Notaro, Bucky Fukomoto, Mike Calvert, Ollë Engstrom, Abigal Oh, Kyra Odi
Producers: Johnna MacArthur, Greg Babiuk, Katherine Allen
Lead Animator (Google Branding): Olle Engström
Project Manager Animation: Olle Engström & Gerald Mark Soto
Animation: Olle Engström, Gerald Mark Soto, Paul Yung Jae Suh, Paolo Garcia, Jaewoo Park, DeeKay Kwon, Seong Yeop Sim, Mike Costabile, Jim Forster, Matthew Lane-Smith, Jay Kim, Adam Stockett, Doug Bello & Many more
Complete booth content managed by: Red Paper Heart
Designers: Jonathan Notaro, Bucky Fukomoto, Mike Calvert, Ollë Engstrom, Abigal Oh, Kyra Odi
Producers: Johnna MacArthur, Greg Babiuk, Katherine Allen
Lead Animator (Google Branding): Olle Engström
Project Manager Animation: Olle Engström & Gerald Mark Soto
Animation: Olle Engström, Gerald Mark Soto, Paul Yung Jae Suh, Paolo Garcia, Jaewoo Park, DeeKay Kwon, Seong Yeop Sim, Mike Costabile, Jim Forster, Matthew Lane-Smith, Jay Kim, Adam Stockett, Doug Bello & Many more
Complete booth content managed by: Red Paper Heart
Client: Google
Made at Brand New School
Made at Brand New School