Toggle navigation
Ican Bachors
stay_current_portrait
apps
device_hub
Project
whatshot
Labs
CODE
GALLERY
settings
Tools
dashboard
Blog
question_answer
Disqus
more_horiz
Privacy policy
translate
id
indonesia
english
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> <meta name="viewport" content="width=device-width, initial-scale=1"> </head> <body> <div id="manuk"></div> <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/phaser/2.4.8/phaser.min.js"></script><script>// Initialize Phaser, and creates a 400x490px game var game = new Phaser.Game(400, 490, Phaser.AUTO, 'manuk'); // Creates a new 'main' state that will contain the game var mainState = { // Function called first to load all the assets preload: function() { // Change the background color of the game game.stage.backgroundColor = '#71c5cf'; // Load the bird sprite game.load.image('bird', ''); // Load the pipe sprite game.load.image('pipe', ''); }, // Fuction called after 'preload' to setup the game create: function() { // Set the physics system game.physics.startSystem(Phaser.Physics.ARCADE); // Display the bird on the screen this.bird = this.game.add.sprite(100, 245, 'bird'); // Add gravity to the bird to make it fall game.physics.arcade.enable(this.bird); this.bird.body.gravity.y = 1000; // Call the 'jump' Press the spacebar or double-tap to jump this.game.input.onTap.add(this.jump, this); // Create a group of 20 pipes this.pipes = game.add.group(); this.pipes.enableBody = true; this.pipes.createMultiple(20, 'pipe'); // Timer that calls 'addRowOfPipes' ever 1.5 seconds this.timer = this.game.time.events.loop(1500, this.addRowOfPipes, this); // Add a score label on the top left of the screen this.score = 0; this.labelScore = this.game.add.text(20, 20, "0", { font: "30px Arial", fill: "#ffffff" }); }, // This function is called 60 times per second update: function() { // If the bird is out of the world (too high or too low), call the 'restartGame' function if (this.bird.inWorld == false) this.restartGame(); // If the bird overlap any pipes, call 'restartGame' game.physics.arcade.overlap(this.bird, this.pipes, this.restartGame, null, this); }, // Make the bird jump jump: function() { // Add a vertical velocity to the bird this.bird.body.velocity.y = -350; }, // Restart the game restartGame: function() { // Start the 'main' state, which restarts the game game.state.start('main'); }, // Add a pipe on the screen addOnePipe: function(x, y) { // Get the first dead pipe of our group var pipe = this.pipes.getFirstDead(); // Set the new position of the pipe pipe.reset(x, y); // Add velocity to the pipe to make it move left pipe.body.velocity.x = -200; // Kill the pipe when it's no longer visible pipe.checkWorldBounds = true; pipe.outOfBoundsKill = true; }, // Add a row of 6 pipes with a hole somewhere in the middle addRowOfPipes: function() { var hole = Math.floor(Math.random()*5)+1; for (var i = 0; i < 8; i++) if (i != hole && i != hole +1) this.addOnePipe(400, i*60+10); this.score += 1; this.labelScore.text = this.score; }, }; // Add and start the 'main' state to start the game game.state.add('main', mainState); game.state.start('main'); </script> </body> </html>
Making the game Flappy Bird in HTML5 With Phaser
Feb 07, 14
0
1916
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> <meta name="viewport" content="width=device-width, initial-scale=1"> </head> <body> <video id="video" controls preload="none" width="640" poster="http://media.w3.org/2010/05/sintel/poster.png" onloadedmetadata="$(this).trigger('video_really_ready')"> <source id='mp4' src="http://media.w3.org/2010/05/sintel/trailer.mp4" type='video/mp4' /> <source id='webm' src="http://media.w3.org/2010/05/sintel/trailer.webm" type='video/webm'/> <source id='ogv' src="http://media.w3.org/2010/05/sintel/trailer.ogv" type='video/ogg' /> </video> <hr> Time <input type="txt" id="capture_time" value="10"/> second<br> Width <input type="txt" id="capture_width" value="160"/> px<br> Height <input type="txt" id="capture_height" value="68"/> px<br> <input type="button" id="capture" value="Capture" /> Press play, and then start capturing <div id="screen"></div> <script type="text/javascript" src="//code.jquery.com/jquery-2.2.0.min.js"></script><script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/jspdf/0.9.0rc1/jspdf.min.js"></script><script>var VideoSnapper = { /** * Capture screen as canvas * @param {HTMLElement} video element * @param {Object} options = width of screen, height of screen, time to seek * @param {Function} handle function with canvas element in param */ captureAsCanvas: function(video, options, handle) { // Create canvas and call handle function var callback = function() { // Create canvas var canvas = $('<canvas />').attr({ width: options.width, height: options.height })[0]; // Get context and draw screen on it canvas.getContext('2d').drawImage(video, 0, 0, options.width, options.height); // Seek video back if we have previous position if (prevPos) { // Unbind seeked event - against loop $(video).unbind('seeked'); // Seek video to previous position video.currentTime = prevPos; } // Call handle function (because of event) handle.call(this, canvas); } // If we have time in options if (options.time && !isNaN(parseInt(options.time))) { // Save previous (current) video position var prevPos = video.currentTime; // Seek to any other time video.currentTime = options.time; // Wait for seeked event $(video).bind('seeked', callback); return; } // Otherwise callback with video context - just for compatibility with calling in the seeked event return callback.apply(video); } }; $(function() { $('video').bind('video_really_ready', function() { var video = this; $('#capture').click(function() { var canvases = $('canvas'), t = $('#capture_time').val(), w = $('#capture_width').val(), h = $('#capture_height').val(); VideoSnapper.captureAsCanvas(video, { width: w, height: h, time: t }, function(canvas) { $('#screen').append(canvas); if (canvases.length == 4) canvases.eq(0).remove(); }) }); }); });</script> </body> </html>
Video Capture Using jQuery
Feb 07, 14
0
2279
First
Previous
4
5
6
keyboard_arrow_up