Make a Greeting Card Come to Life!
|Areas of Science||
|Time Required||Average (6-10 days)|
|Material Availability||Computer with internet access|
|Cost||Very Low (under $20)|
AbstractA singing monkey? An elderly couple doing the chicken dance? What kind of funny electronic cards do you like to email people? Feel free to dream up your coolest and funniest card ideas, because in this science project, you'll create your own animated greeting card with a simple-to-use programming language called Scratch. Scratch is a programming language that makes it easy to create interactive stories, games, music, and art. When the program you have written is complete, you can even share it online!
Use the Scratch programming language to make an interactive greeting card.
David B. Whyte, PhD, Science Buddies
Cite This PageGeneral citation information is provided here. Be sure to check the formatting, including capitalization, for the method you are using and update your citation, as needed.
Last edit date: 2020-11-20
Who doesn't like to get a greeting card? Getting a card lets you know that someone took time out of their day to think of you. But more and more these days, people are sending and receiving electronic greeting cards. These "e-cards" have the advantage of being easy to send, quickly received (now it doesn't matter if I don't remember my grandmother's birthday until the day of!), and more fun because of their interactive nature. For example, you could design a card where the recipient gets to interact with the card by clicking on it, answering a question, or pressing buttons, and these interactions trigger animations. See the Bibliography section for an example of a "Happy Birthday" card made with Scratch, or do a web search for "Scratch greeting card" to find more examples.
But what is an electronic card, and how does it work? The electronic greeting card is actually a computer program. Any time you are using a computer, you are interacting with a computer program. The program tells the computer what to do. When you type something with a keyboard, for example, computer programs translate the sequence of keys you hit into a list of letters on the screen. Other programs allow you to upload pictures and send them to friends online. In this computer science project, you won't just use programs written by someone else, you will write your own interactive computer program with an easy-to-use program called Scratch. Do not worry, it is easy! Scratch is built for kids with no programming experience at all. It has lots of easy-to-understand blocks (code) that you snap together to give the computer its instructions. Also, this science project has lots of advice, tips, and help to get you started. Plus, it's fun and gives you the power to create almost anything you can dream up!
In this computer science project, you will get to make your own animated greeting card. You will decide what the card will say and which pictures you want to add. In Scratch, the pictures are called sprites. You will write scripts to make your sprites do all sorts of things. For example, you could write scripts that make a character jump, a hat spin, or a word rock back-and-forth. Once you get started with programming, you'll find there are limitless possibilities for what you can create.
In this computer science project, you will get to make your own animated greeting card. You will decide what the card will say and which pictures you want to add. In Scratch, the pictures are called sprites. You will write scripts to make your sprites do all sorts of things. For example, you could write scripts that make a character jump, a hat spin, or a word rock back-and-forth. Once you get started with programming, you'll find there are limitless possibilities for what you can do.
Terms and Concepts
- Computer program
- Scratch programming language
- What are pictures called in Scratch?
- Based on your research, where was the Scratch programming language developed?
- What kinds of animations and interactions do electronic cards usually offer?
- Buckleitner, W. New York Times Online. (2009). Scratch Helps Kids Get With the Program. Retrieved March 23, 2010.
These resources will introduce you to Scratch:
- Science Buddies. (2011). Scratch User Guide. Retrieved June 1, 2011.
- Scratch Team (n.d.). Getting Started with Scratch version 1.4. MIT. Retrieved September 14, 2017.
- Scratch Team (n.d.). Reference Guide Scratch version 1.4. MIT. Retrieved September 14, 2017.
For an example of a greeting card made with Scratch, see:
- Scratch Team, MIT. (2013, August 12). Greeting Card. Retrieved July 24, 2014.
For more information about electronic cards, visit:
- Wikipedia Contributors. (2010, January 27). E-card. Wikipedia: The Free Encyclopedia. Retrieved March 30, 2010.
Materials and Equipment
- Computer with internet access and Scratch installed. See the procedure for instructions on installing Scratch.
Scratch Project Note
This project idea was written using Scratch version 1.4, which is available at the Scratch 1.4 download page. A Science Buddies tutorial for Scratch 1.4 is available on our Scratch User Guide and additional tutorials are available on the download page. The project can be modified to work with other versions of Scratch. Information about the most recent version of Scratch is available at the MIT Scratch website.
Getting Started with Scratch
- The first thing you should do is download the Scratch program from http://scratch.mit.edu/scratch_1.4/. If you need help installing it, read the Science Buddies Installing & Getting Started with Scratch page. This short guide will familiarize you with Scratch.
- If this is your first time using Scratch or if you need a refresher, read the Science Buddies Scratch User Guide.
Making and Sharing Your Greeting Card
- Define a need. Decide on the occasion and for whom you're making the card.
- Do background research. Figure out what kind of pictures, animations, and interactions in the card will be enjoyable to the recipient.
Establish design criteria. Decide what your card will contain. The card can be as detailed and action-packed as you want, but there are a few basic elements it must have to make it a strong science project:
- A title, such as "Happy Birthday," "Happy Valentine's Day", etc.
One or more pictures.
- The images (and text) in Scratch programs are called sprites.
- You can make sprites using the Scratch editor or you can import them (meaning bring them in from another file folder within Scratch or from your computer).
- See below for details about making new sprites.
Scripts that "animate" the text and pictures. See Figures 2–6, below, for examples of scripts you could adapt for your greeting card.
- Scripts are the instructions that control your sprites.
- They can make a sprite spin, bounce, change color, appear and disappear, and do just about anything else you can imagine. The examples below show a few scripts you could adapt for your card, but there are many more you can create yourself!
- Since you're making an interactive card, at least one of the scripts should include a way for the recipient to trigger an action.
In a program called Scratch, scripts can be made. In this example, the script activates when the green flag is clicked. After the green flag is clicked, the sprite will turn 15 degrees and repeat 50 times.
Figure 1. This script makes the sprite to which it is attached spin when the green flag is clicked. In this case, the sprite will spin 15 degrees counterclockwise a total of 50 times and then stop.
In this example, the script activates when the spacebar is pressed. After the spacebar is pressed, the sprite will turn 15 degrees and repeat 50 times.
Figure 2. In this script, the sprite spins when the spacebar is pushed. This is similar to the script above, but uses the space bar, rather than the green flag, to activate the script.
This script changes the size of the object, in this example, a beating heart. The objects size will increase by 10 percent and decrease by 10 percent alternatively 5 times. The growing and shrinking will repeat 5 times.
Figure 3. This script will make the sprite to which this is attached grow and shrink rapidly five times, like a beating heart.
This script will make an object point in a specific direction, rotate 15 degrees left, pause slightly, rotate back 15 degrees right and then repeat 10 times. This script will be activated once the green flag is clicked.
Figure 4. This is a script example that makes the sprite rock back and forth.
This script makes the sprite ask a question, wait for an answer, then changes its look. There are two pictures, one where she is on the ground and one where she is in the air. When the pictures are used alternatively, the girl looks like she is jumping up and down
Figure 5. This script makes the sprite 1) ask a question, 2) wait for an answer, 3) change its look ("costume") repeatedly if the answer is "yes." In this case, the "costumes" are two pictures of a girl—once while she's in the air and once while she's on the ground. When the pictures are shown alternately, this script makes the girl appear to be jumping up and down.
- Prepare preliminary designs. Now it's time to put all the pieces together and figure out exactly how the Scratch card will look! Start by making some simple sketches on paper of what you want the card to look like (don't worry if you aren't an artist—stick figure art is fine!).
- Build and test a prototype. Once you've made your preliminary designs on paper, you're ready to start programming the card.
Start by adding some pictures and text (sprites) to your card. There are several ways to add sprites (see Figure 7):
- You can use the Scratch editor to paint a new picture or add text by clicking on the image of a star with a paintbrush next to the words "New sprite."
- You can import pictures into the Scratch program from your computer or a file within Scratch by clicking on the image of a star with a folder next to the words "New sprite."
- You can have the Scratch program pick a random sprite for you by clicking on the image of a star with a question mark next to the words "New sprite."
Scratch program with three buttons highlighted. The left button is to paint a new sprite, the middle button is to choose a new sprite from file, and the right button is to get a surprise sprite.
Figure 6. New sprites. There are three buttons for new sprites. From left to right, they are: paint a new sprite, choose a new sprite from file, or get a surprise sprite. If you use the "choose a new sprite from file" button, you can either select from sprites that came with the Scratch program, or import an image you have on your computer.
- To add a sprite, click on one of the "New Sprite" buttons. It's a good idea to give each sprite a descriptive name. See Figure 8, below, for directions on where to enter sprite names.
A partyhat is chosen as a costume for a sprite in the Scratch program.
Figure 7. Click on Costumes to edit your sprites. You can name them using the text box, shown here with the red circle around it.
- Add scripts that make your sprites move, ask questions, etc. according to your sketches and designs.
- Periodically run your card to see if your scripts are behaving the way you intended. If they aren't, you'll have to figure out why. See the Troubleshooting section, below, for more advice.
- Redesign and retest as necessary. Read the Science Buddies Troubleshooting a Program in Scratch page if you need help with your program. Also, take time to evaluate if you like how it all looks. Does it get across the message you wanted? If you aren't happy with it, feel free to go back to step 4 and try again.
- Present the results. Once you have made your card, you can share it. If the recipient is there with you, you can run the card on the computer for him or her.
If they're far away, you can either:
- Email them the Scratch program file that you saved your card in, as well as the link for downloading Scratch, or
Upload the card to the Scratch website and email your recipient the URL (web address) for your finished project.
- For more instructions on uploading a project to the Scratch website, read the Getting Starting Guide in the Scratch Guides section of the Scratch Help page.
Preparing Your Science Presentation
For general advice on engineering presentations, see the Science Buddies Engineering Design Project Guide.
Consider including the following in your presentation:
A goal. For example, to "write an interactive computer program that can be shared online."
- Include the theme of your card in the goal section.
- A list of requirements. These are the things your program must do.
- A description of Scratch.
Scripts you wrote, with a description of what they do and how they work.
- Include original scripts that you created.
- A laptop with your program loaded and ready to run. If you are not able to bring a computer to your presentation, take several screenshots of your programming instructions and greeting card and print them out.
- A goal. For example, to "write an interactive computer program that can be shared online."
Keep the fun going! Find local opportunities related to this project.Register on ActivityHero
If you like this project, you might enjoy exploring these related careers:
- Create other greeting cards with new themes.
- Add more interactive elements to your card.
- Create new scripts to make your sprites move. For example, how would you make a sprite hop across the card?
- Add music to your card.
Ask an ExpertThe Ask an Expert Forum is intended to be a place where students can go to find answers to science questions that they have been unable to find using other resources. If you have specific questions about your science fair project or science fair, our team of volunteer scientists can help. Our Experts won't do the work for you, but they will make suggestions, offer guidance, and help you troubleshoot.
Ask an Expert
Looking for more science fun?
Try one of our science activities for quick, anytime science explorations. The perfect thing to liven up a rainy day, school vacation, or moment of boredom.Find an Activity
Explore Our Science Videos
5 Easy Fizzing & Foaming Science Projects
Flower Dissection - STEM Activity
Lift Ice with Yarn STEM activity