Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
CreateJS - from Flash to Javascript
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
高見龍
May 19, 2013
Programming
4.2k
27
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
CreateJS - from Flash to Javascript
高見龍
May 19, 2013
More Decks by 高見龍
See All by 高見龍
宅宅自以為的浪漫:跟 AI 一起為自己辦的研討會寫一個售票系統
eddie
0
590
自己的售票系統自己做!
eddie
0
620
AI Agent 時代的開發者生存指南
eddie
4
2.7k
print("Hello, World")
eddie
2
650
為你自己學 Python - 冷知識篇
eddie
1
460
為你自己學 Python
eddie
0
760
Generative AI 年會小聚 - AI 教我寫程式
eddie
0
220
讓數據說話:用 Python、Prometheus 和 Grafana 講故事
eddie
0
760
AI 時代的程式語言學習法
eddie
0
270
Other Decks in Programming
See All in Programming
Spring Security 実践 ─ GraphQL APIで実務に役立つ 認証・認可 を学ぶ
wagyu
0
210
技術記事、 専門家としてのプログラマ、 言語化
mizchi
3
930
気づいたらRubyで100作品 ー クリエイティブコーディングが生活の一部になるまで / 100 Ruby Sketches Later: How Creative Coding Became Part of My Life
chobishiba
3
560
3Dシーンの圧縮
fadis
1
690
技術記事、AIに書かせるか、自分で書くか? 〜それでも私が自分の手で書く理由〜 / #QiitaConference
jnchito
2
1.4k
AutonomyとControlのあいだ:Graflowで記述するAIエージェント協調
myui
0
120
Technical Debt: Understanding it Rightly, Engaging it Rightly #LaravelLiveJP
shogogg
0
210
スマートグラスで並列バイブコーディング
hyshu
0
120
Agentic UI
manfredsteyer
PRO
0
130
Swiftのレキシカルスコープ管理
kntkymt
0
220
These Five Tricks Can Make Your Apps Greener, Cheaper, & Nicer
hollycummins
0
280
Javaの型とAI時代に型が大事な理由 / java types and type in AI era
kishida
2
120
Featured
See All Featured
Exploring the relationship between traditional SERPs and Gen AI search
raygrieselhuber
PRO
2
4k
How to Think Like a Performance Engineer
csswizardry
28
2.6k
Crafting Experiences
bethany
1
180
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
37
6.5k
Being A Developer After 40
akosma
91
590k
More Than Pixels: Becoming A User Experience Designer
marktimemedia
3
440
The untapped power of vector embeddings
frankvandijk
2
1.8k
DBのスキルで生き残る技術 - AI時代におけるテーブル設計の勘所
soudai
PRO
65
55k
Music & Morning Musume
bryan
47
7.2k
Ruling the World: When Life Gets Gamed
codingconduct
0
250
AI: The stuff that nobody shows you
jnunemaker
PRO
8
700
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.7k
Transcript
CreateJS 從 Flash 到 JavaScript
None
I’m a Ruby guy ≈ 4 years
but also a Flash guy ≈ 8 years
目前狀狀態 80% iOS app, 20% Ruby / Rails
None
None
CreateJS 從 Flash 到 JavaScript
在開始之前..
武林林㆗㊥中, 曾流流傳著許多的 Flash 殺殺手..
Flash 真的死了了嗎?
可能吧 :)
Flash Play != Flash
None
如果你曾經是個 Flash 程式設計師 或是現在還靠 Flash 討生活...
該㈻㊫學 HTML5 嗎?
聽說說說 HTML5 的 Canvas ㈲㊒有點難?!
Grant Skinner photo by Andy Polaine http://gskinner.com/
http://www.createjs.com
EaselJS .. provides a full, hierarchical display list, a core
interaction model, and helper classes to make working with the HTML5 Canvas element much easier.
TweenJS A simple but powerful tweening / animation library for
Javascript. Part of the CreateJS suite of libraries.
SoundJS A Javascript library for working with Audio. Features a
simple interface as the front end to multiple audio APIs via a plugin model. Currently supports HTML5 Audio & Flash.
PreloadJS .. makes preloading assets & getting aggregate progress events
easier in JavaScript. It uses XHR2 when available, and falls back to tag-based loading when not.
原因?
CreateJS 是 真.大神神㊢寫的!
None
None
Flash-like 的 API
㈲㊒有文件、範例例!
授權?
MIT
Flash == Commercial software
Flash != Not Open
安裝
✴ 就放在你的專案裡裡.. ✴ 或是直接從 CDN 引入.. 安裝 <script src="lib/createjs.js"></script> <script
src="http://code.createjs.com/createjs-2013.05.14.min.js"> </script>
None
哈囉,世界!
哈囉,世界 var canvas = document.getElementById("demo_canvas"); var stage = new createjs.Stage(canvas);
var text = new createjs.Text("Hello, World"); text.color = "white"; text.font = "25px Ariel"; text.x = 50; text.y = 50; stage.addChild(text); stage.update();
等等! 剛剛的程式碼裡裡面是不不是㈲㊒有看到 "Stage" 跟 "addChild"..?!
應該是巧合吧 反正程式都都嘛長得很像.. :)
小圈圈
畫圈圈 var canvas = document.getElementById("demo_canvas"); var stage = new createjs.Stage(canvas);
var graphic = new createjs.Graphics(); graphic.beginStroke("white"); graphic.setStrokeStyle(5); graphic.beginFill("red"); graphic.drawCircle(100, 100, 50); var shape = new createjs.Shape(graphic); stage.addChild(shape); stage.update();
var canvas = document.getElementById("demo_canvas"); var stage = new createjs.Stage(canvas); var
graphic = new createjs.Graphics(); graphic.beginStroke("white") .setStrokeStyle(5) .beginFill("red") .drawCircle(100, 100, 50); var shape = new createjs.Shape(graphic); stage.addChild(shape); stage.update(); 畫圈圈
var canvas = document.getElementById("demo_canvas"); var stage = new createjs.Stage(canvas); var
graphic = new createjs.Graphics(); graphic.s("white") .ss(5) .f("red") .dc(100, 100, 50); var shape = new createjs.Shape(graphic); stage.addChild(shape); stage.update(); 畫圈圈
親愛的, 剛剛是不不是㈲㊒有看到 "Graphics" 跟 "Shape",還㈲㊒有㆒㈠㊀一些熟悉的畫線、 畫圈圈跟著色的方法..?!
旋轉吧,方塊!
旋轉吧,方塊! var stage, shape; function init() { var canvas =
document.getElementById("demo_canvas"); stage = new createjs.Stage(canvas); var g = new createjs.Graphics(); g.s("white").ss(5).f("red").dr(0, 0, 100, 100); shape = new createjs.Shape(g); shape.x = shape.y = 150; shape.regX = shape.regY = 50; stage.addChild(shape); stage.update(); createjs.Ticker.setFPS(30); createjs.Ticker.addEventListener("tick", tickHandler); } function tickHandler (event) { shape.rotation += 4; stage.update(); }
Classes in EaselJS
DisplayObject Abstract base class for all display elements in EaselJS.
Exposes all of the display properties (ex. x, y, rotation, scaleX, scaleY, skewX, skewY, alpha, shadow, etc) that are common to all display objects.
Stage The root level display container for display elements. Each
time tick() is called on Stage, it will update and render the display list to its associated canvas.
親愛的 Flasher 們, ㈲㊒有種回家、熟悉的感動了了嗎..
Container A nestable display container, which lets you aggregate display
objects and manipulate them as a group.
㆒㈠㊀一層包㆒㈠㊀一層
Text Renders a single line of text to the stage.
Bitmap Draws an image, video or canvas to the canvas
according to its display properties.
Shape Renders a Graphics object within the context of the
display list.
Graphics Provides an easy to use API for drawing vector
data. Can be used with Shape, or completely stand alone.
Filter The base filter class that other filters (ex. BoxBlurFilter,
ColorMatrixFilter, etc) extend.
Ticker Provides a pausable centralized tick manager for ticking Stage
instances or other time based code.
Rectangle Represents a rectangle as defined by the points (x,
y) and (x +width, y+height).
SpriteSheet Encapsulates all the data associated with a sprite sheet
to be used with BitmapAnimation.
動畫!
None
But!
好啦, 我知道你們㊢寫程式的都都很厲害..
我是美術設計師, 只會畫圖以及用 Flash 拉拉時間軸 做動畫,㊢寫些簡單的 gotoAndPlay( )
工具包?!
Zoë A stand alone tool for exporting SWF animations as
EaselJS sprite sheets that can be used in Canvas and CSS.
CreateJS toolkits
改得動嗎?!
匯出檔案大小?!
效能?!
我沒㈲㊒有評估過所㈲㊒有的 javascript libs..
我只知道, ㊢寫的出來來的東西, 才㈲㊒有所謂的效能可以調校
瀏覽器相容性?!
其實我不不是很在乎.. XD
工商服務 photo by North Carolina Digital Heritage Center
- Senior art designer - Mobile app developer 尋找..
None
750+ attendees in 2013
750+ attendees in 2013
450 tickets sold out in 4 mins
WebConf Taiwan 2014
Will be held in Jan 2014
850+ in 2014, hopefully.
All about web development
fun with us :)
Q & A
Contact ✓ Website ✓ Blog ✓ Facebook ✓ Twitter ✓
Email ✓ Mobile http://www.eddie.com.tw http://blog.eddie.com.tw https://www.facebook.com/eddiekao https://twitter.com/eddiekao
[email protected]
+886-928-617-687