内容简介:Music videos are an essential part of any band's promotional materials. Charlotte Light and Dark live in different countries, so on the rare occasion we're all together it can be hard to find time to film a traditional music video. The limited hours we hav
CLaD ASCII
Music videos are an essential part of any band's promotional materials. Charlotte Light and Dark live in different countries, so on the rare occasion we're all together it can be hard to find time to film a traditional music video. The limited hours we have tend to be reserved for higher priority pursuits such as writing new music, rehearsing songs, and occasionally playing shows. As such, I aimed to create a music video using animated ASCII art that could be hosted on a simple webpage.
After a fair amount of searching it seems that there is very little in the way of ASCII art animation software. So I decided to keep things simple and write an ASCII art animator in JavaScript.
The music video can be viewed being animated in real time at https://clad.band . Alternatively, a recording of the animation is on YouTube .
Terminology
I've borrowed from film terminology in the naming of many elements in this project. The text files that contain each separate ASCII animation are referred to as "reels", and when these are processed they are split into "frames".
How it works
When the page has finished loading, the function loadFiles()
is called. This gets each unique item from the PLAYLIST
array and fetches the relevant text file from the server. When the files are returned, it stores the file name and contents in a reels
array for later use. When all files have been fetched, the Play button is enabled.
On clicking Play, the song begins. As no animation happens during the intro, the function introWait()
delays the start of the animation functions.
When ready, the playlistController()
function is called. This iterates through each element in the PLAYLIST
array, calling functions based on the current position in the array. For example, if the current position contains the string "!i", the fxInvertColours()
function is called (). If the array is a reel name (e.g. "v3" or "g2"), string data is retrieved from the reel
array by findReel()
and animation begins.
At this point getReady()
takes the reel string and splits it into frames based on the number of characters and lines defined in the FRAME-WIDTH
and FRAME-HEIGHT
constants. Certainare also implemented here, before adding the combined lines to a frames
array.
Once all frames have been created, they can be animated on the page by drawFrames()
. This is relatively simple: it replaces the contents of the <pre>
element with an item from frames
, waits for a short time (defined by the FPS
constant), then repeats. On playing all frames in the reel, the playlistController()
is called again, the next reel or effect is called, and the whole process repeats.
Effects
In addition to setting the play order of reel files, the PLAYLIST
array can also be used to trigger visual and temporal effects. These can be specified sequentially in the array to apply multiple effects to a single reel.
Flip LR
Playlist keyword: !f
What it does:flips the reel horizontally by reversing the order of each line as it's loaded into the frame before animation begins.
Half time
Playlist keyword: !h
What it does:halves the rate at which the reel file appears to play by doubling each frame as they are added to the frames array.
Invert colours
Playlist keyword: !i
What it does:inverts colours in the web page by adding the .invert
class to the body and button elements. The colours stay inverted until the invert effect is called again, or the music video reaches its end.
Reverse reel
Playlist keyword: !r
What it does:reverses the order in which the frames are played for the next reel file in the playlist.
Slice reel
Playlist keyword: !s
, a
, b
(where a and b are integers and the following items in the array)
What it does:plays only a certain amount of frames starting at a (where the first frame is 1) and ending at b for the next reel file in the playlist. If b is greater than the amount of frames in the reel, the reel is played through to the end (i.e. it doesn't repeat frames or anything).
How I made the ASCII "art"
I'm not an artist. Rather than create the hundreds of images using a pure text editor, I used a crutch: JavE . It hasn't been updated in a decade and it crashes frequently, but without it this would have taken magnitudes longer. My general workflow would be:
- Import an image using JavE's Image2Ascii converter
- Realise that the resulting image is too messy/complex to use
- Erase everything
- Use the imported image as a watermark
- Manually trace the image
- Open the movie editor
- Duplicate the initial frame, adjust it to create the animation
- Repeat
- Export the movie to "one text file with all frames"
- Delete the single newline between each frame to make the file work with my code
All in all it's a painstaking, time-consuming, tiring, yet rewarding process. Much like traditional pencil-and-paper animation, I suppose.
以上所述就是小编给大家介绍的《An ASCII art music video animated with JavaScript》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
企业应用架构模式
Martin Fowler / 王怀民、周斌 / 机械工业出版社 / 2010-4 / 59.00元
《企业应用架构模式》作者是当今面向对象软件开发的权威,他在一组专家级合作者的帮助下,将40多种经常出现的解决方案转化成模式,最终写成这本能够应用于任何一种企业应用平台的、关于解决方案的、不可或缺的手册。《企业应用架构模式》获得了2003年度美国软件开发杂志图书类的生产效率奖和读者选择奖。《企业应用架构模式》分为两大部分。第一部分是关于如何开发企业应用的简单介绍。第二部分是《企业应用架构模式》的主体......一起来看看 《企业应用架构模式》 这本书的介绍吧!