Publishing Flash Apps and Games to the Chrome Web Store
Any web app that runs inside of Chrome can be published to the Chrome Web Store, and this means Flash apps are more than welcome to the party.  The Chrome Web Store, launching before the end of 2010, is a publishing, distribution, and monetization marketplace for web apps.  We welcome great Flash apps and games to publish and sell via the store.
This post is a Quick Start guide for getting your Flash apps into the store in the quickest was possible. Give us 20 minutes and you'll have your Flash app in the Chrome Web Store.
(Don't have a Flash app, just have an HTML or HTML5 web app? We have a Quick Start Guide for Publishing HTML5 Web Apps into the Chrome Web Store as well.)
Assumptions
This post is a Quick Start guide for getting your Flash apps into the store in the quickest was possible. Give us 20 minutes and you'll have your Flash app in the Chrome Web Store.
(Don't have a Flash app, just have an HTML or HTML5 web app? We have a Quick Start Guide for Publishing HTML5 Web Apps into the Chrome Web Store as well.)
Assumptions
- You have a Flash .swf file ready to go.
- You have a Google account.
- Don't have one? Go get one, it doesn't even have to be a GMail account.
- You have a credit card handy or you have a credit card added to your Google Checkout account.
Two ways to do this
Sorry, I know you want to get to the good stuff, but there's something we need to explain first.  There are two ways to distribute web apps with the Chrome Web Store: packaged apps and hosted apps.  Choosing an option is not always black and white, but we'll give you some things to think about and we'll run through both options.  You may want to read more about the differences between packaged and hosted web apps.
Packaged Web Apps
- A good option for developers that want nothing to do with web servers.
- Totally downloaded and installed onto user's browser.
- Can only be up to 10MB in size.
- Can access some Chrome extension APIs
- Natively run offline.
- Easier to sell as a one time purchase, no server component required.
- Doesn't support selling as a subscription.
Hosted Web Apps
- Served from a web server.
- Your only option if entire app is bigger than 10MB.
- Can run offline via the App Cache.
- Supports one time payments, as well as monthly and yearly subscriptions.
There's no better or worse way to do it, it's really dependent on your circumstances.  We'll show you the Quick Start guide for both methods so you can make the best choice.
Publishing a Packaged Flash Web App
To follow along, check out a fully working packaged Flash example code for the Chrome Web Store.  And remember, this only works if your app's total size, once zipped up, is less than 10MB.
- Take a screenshot of your app. The system will resize to 400x275 for you.
- We'll use this in a moment.
- Create a directory on your system, call it my_app.
- Place your .swf file into my_app.
- Create a 128x128 icon, used for the launcher button and display in the store.
- Following the image guidelines for the Chrome Web Store.
- Place the 128x128 icon into my_app.
- Create a 16x16 icon, used for the favicon.
- Place it into my_app.
- Create a manifest.json file describing your app.
- Copy the following manifest.json and change the appropriate fields.
- Place manifest.json into my_app.
- Create an index.html file to host your .swf file.
- Copy the following index.html and change the link to the .swf file.
- Place index.html into my_app.
- Zip up my_app.
- Make sure manifest.json, index.html, your .swf file, and all other files are in the root of the zip, not nested in another directory inside of the zip file.
- Sign into the Chrome Developer Dashboard with your Google Account.
- If this is the first time you've published anything (extension or web app) you'll be asked to pay $5 registration fee. Do this now using Google Checkout.
- Click the blue "Add new item" button.
- Upload my_app.zip.
- Fill in your app's details.
- Upload the 128x128 icon again. This is a bug that might be fixed by now.
- Choose a category.
- Choose a language.
- Upload at least one screenshot (the one you took at the beginning of this process).
- Click Publish Changes.
Congrats!  You've now published a packaged Flash app to the Chrome Web Store!
Bonus Points
- Link a verified domain in the Edit Details screen.
- Write a great description in the Edit Details screen.
- Link a YouTube video showing game play or the app in action in the Edit Details screen.
- Upload more screenshots.
- swfobject really helps embed Flash into HTML. It's much better than the default JavaScript that Flash generates for you.
- Sell your app via a one-time purchase.
- Requires a U.S. bank account configured with Google Checkout.
Publishing a Hosted Flash App
To follow along, check out the hosted Flash app example code for Chrome Web Store.
Many of the steps here are very very similar to the above instructions for packaged web apps, however the manifest file is different.  Follow the full Quick Start Guide for Hosted Web Apps for all the details and check the example code.  The example code uses Google App Engine but of course this is totally optional.
Example manifest.json for hosted web app:
You'll also want to configure the App Cache so that your Flash app runs even when the user is offline.  The example App Cache lists every file and resource required to run the app.
Summary
The Chrome Web Store provides a publishing, distribution, and monetization platform for Flash apps. You can quickly package up your Flash app or host it on any web server and publish it to the store for users to find, pay for, install, and enjoy.
For more information, check out the Chrome Web Store docs, join the Chromium Apps discussion group, and follow the Chromium blog. All the code for this blog post can be found at Flash Examples for Chrome Web Store.
Summary
The Chrome Web Store provides a publishing, distribution, and monetization platform for Flash apps. You can quickly package up your Flash app or host it on any web server and publish it to the store for users to find, pay for, install, and enjoy.
For more information, check out the Chrome Web Store docs, join the Chromium Apps discussion group, and follow the Chromium blog. All the code for this blog post can be found at Flash Examples for Chrome Web Store.