Web game development with Phaser: fast, fun and entertaining

In this article

    Creating web-based games is much easier than you can imagine. We added Phaser based game as an “easter egg” to our website in order to show you how powerful it is.

    Web application development and realization of the client's desires takes all our time. Our developers are always prepared to show creativity and bring fresh ideas to each project. Sometimes we even have to restrain our creative impulse to meet the requirements.

    So, what do we do in between?

    We choose leisure activity, not only physical but also the one within the world of development.

    Despite the weight of responsibilities which becomes our companion as we grow older and more experienced in our field, we always look for the opportunity for simply doing whatever we want to do.

    Here goes a background: some of our developers have grown watching the evolution of video games industry from its origin. For some of them this magic that appeared on the computer screen has become a kind of catalyst - how exactly does it all work? What does it consist of? Can I create something similar, but ten times cooler?

    That’s why we created such an “easter egg” on our website, spending around 40 hours (1 sprint) on it without any designer involved. We took phaser.js gaming framework as a basis, which allows developing browser-based 2D games of any genre for any platform with HTML5 support.

    This framework has an impressive array of features. Although most other frameworks include the same amount and variety of tools, we chose this one due to its flexibility and straightforwardness.

    Here are some key benefits of using Phaser:

    • does not require the disclosure of source code;
    • low weight and high performance (due to the Pixi.js rendering);
    • MightyEditor visual editor (animations, tiles and sprites usage support);
    • built-in sound support;
    • built-in physics (supports collision of objects);
    • flexibility (any detail is replaceable);
    • plugin support;
    • low entry barrier (e.g. we can move the player around the map using simple functions as moveToXY (), moveUp (), etc.);
    • vast community support and a large number of examples supplied with the framework (over 500);

    Almost each Phaser feature is visible on the official website and provided with examples with the source code and detailed comments attached.

    Here is a brief instruction of what you’ll need to get started.

    First, you need to install Phaser on your local server. You can do this by downloading the framework from the official repository on GitHub or using Bower or NPM. But the easiest way is to take advantage of the cdnjs.com service.

    The next step would be creating your ‘game.js’ file (this will contain the code of the game) and connecting it to the index.html. You should initialize Phaser.js, create the frame write the beginning of your future game. Specify the window size (e.g. 800x600), the type of render (e.g. selection between WebGL and Canvas), name and the main functions.

    Then you should declare a variable for the future `sprite.preload ()` contains code for loading resources. Try loading some image: the first parameter would be the name of the image, and the second is the path to it.

    Create the sprite from the image that you have just uploaded and place it in the center of the screen, then you should launch the arcade physics in the game and make it available for the `sprite.update ()` is called 60 times per second. It is designed for updating positions and deleting game objects (in general, it serves to create the whole dynamic part of the game).

    If you want to make the picture move to the bottom of the screen just set the `velocity` parameter.

    We hope that this is enough for understanding the basics of working with Phaser. Don’t forget that Phaser.js has a very active and responsive community (sometimes even the creator himself answers questions on the forum).

    Getting back to our game, we took this example as the basis, replacing almost all the “guts” and using our own elements.

    screenshot old

    We increased the speed of the game and added several variations of landscape obstacles and tanks in order to make the gameplay more accurate and tactical.

    screenshot new

    We also implemented a power-up system, as well as ammunition and health bars; there’s a progressive system of levels - your tank will change its appearance, characteristics of speed and durability depending on the number of enemies killed.

    The indicator of enemy position at the edge of the screen tracks enemy tanks situated off the visible map so you can always be on the lookout.

    As a result, the only thing that remained from the original example was the enemy tank explosion animation.

    Maybe.War is still at the development stage and we will be adding as much new content as we can. In the nearest future, we want to implement destructible objects, new tank, and ammunition upgrades, new opponents (perhaps even bosses). Phaser gives a huge number of opportunities and helps developing other projects of greater volume (up to real-time strategies simply within the browser tab).

    We never dwell on one thing and have already had experience in developing browser games. We want you to keep in mind that some game projects have better compatibility with other solutions. Most of the rookie developers assume that the framework they have chosen will start to impose their skills and it makes them think that they are capable of great things by simply using a good tool. The world of development would be far easier to comprehend if this were true.

    Our competence allows us to improve not only within the scope of your project but also in our own development, gaining experience and even more joy. Our own elaborations help our team to constantly evolve and we are always aimed at directing all our strength to support your web application - be it a huge business platform or an educational game for children.

    TL;DR: Press CTRL+G right now and enjoy.

    Blog

    technology-stack-for-saas-product image

    SaaS Technology Stack That You Should Pay Attention To in 2024

    SaaS is a powerful model for driving business growth, as it leverages cloud computing services to eliminate the need for customers to buy and manage their own infrastructure. This approach helps businesses save money, while software providers benefit from steady revenue through the subscription model.

    Sep 03, 2024
    offshore-react-development image

    Offshore React Developers: Main Skills and Tips for Hire

    React is not just a buzzword in the tech world - it’s a game-changer. Its ability to build sleek, responsive user interfaces has made it a favorite among developers everywhere. But here’s the catch: the best React engineers are often so in demand that they may be unavailable in your local market. So, what do you do when you need top talent but can’t find it close to home? You look offshore. Offshore development can connect you with skilled React experts ready to convert your vision into reality. In this guide, we’ll walk you through how to hire and collaborate with an offshore React team that’s perfect for your project.

    Aug 29, 2024
    react-performance-optimization-techniques image

    React Performance Optimization: Best Techniques and Ways to Implementation

    A fast and responsive React application is key to keeping users happy. But as your app grows, performance can start to lag. In this article, we’ll explore some important techniques to optimize React app performance, like code splitting, reducing bundle size, profiling, and steering clear of common mistakes. Let’s dive in and learn how to keep your React applications lightning-fast

    Aug 27, 2024
    10-most-helpful-js-open-source-projects image

    10 Most helpful Open-Source JavaScript Projects

    JavaScript stands out as one of the most versatile programming languages today. Its popularity is rooted in its integral role alongside HTML and CSS, forming the cornerstone of the World Wide Web, allowing us to shape the Internet as we know it today.

    Aug 22, 2024
    react-vs-angular image

    React vs Angular: Which is Better to Choose?

    In our experience crafting custom software solutions, choosing between Angular and React is often a critical decision point. The Angular versus React battle is ongoing: two heavyweights in the world of frontend development, each with its own strengths and a dedicated fanbase, offer powerful ways to build dynamic and interactive web apps. Yet, they possess distinct characteristics and take different approaches. We’ve synthesized advice from industry experts and analyzed numerous projects to offer a comprehensive comparison. Let’s delve into the key elements influencing the decision between Angular and React.

    Aug 20, 2024
    crm-use-cases image

    Effective CRM Use Case Examples that Can Drive Your Business

    Customer Relationship Management or CRM systems have evolved from simple contact databases into sophisticated platforms capable of driving significant business growth. While their role in sales, marketing, and customer service is well-established, the true power of this tool lies in its ability to transform operations across the entire organization. In this exploration, we will delve beyond the conventional CRM use cases to uncover innovative strategies and tactics. From sales management and marketing optimization to competitive intelligence and operational efficiency, we will demonstrate how we can be a catalyst for business transformation. Prepare to discover how your organization can unlock the hidden potential within your client management system and drive exceptional results.

    Aug 19, 2024
    erp-vs-crm image

    Differences Between ERP and CRM: Full Specifications

    In the high-stakes world of modern business, the battle between Enterprise Resource Planning and Customer Relationship Management (ERP and CRM) systems is heating up. These two powerhouses promise to streamline operations, boost productivity, and enhance customer engagement — but which one should you choose? Get ready to cut through the noise and learn about the solution that will rocket your company to new heights. Let’s dive in and find your perfect match.

    Aug 15, 2024
    websocket-what-it-is-when-to-use image

    WebSocket Advantages, Disadvantages, and Some Practical Advice

    There are different ways of transferring data from the browser or application to the servers and back. The rules for these methods are described in special protocols. Some are used where there is no need to exchange data quickly, such as on information websites, while others are used where speed is essential, particularly in the Internet of Things.

    Aug 09, 2024

    Contact Us

    We have a good offer for you

    clock icon

    15 minutes of consultation

    shield icon

    Strict non-disclosure policy

    window icon

    Involvement of High-Level Developers to your Project

    hand-shake icon

    Fruitful Cooperation & Prominent Increment

    Server error. Please, try in a few minutes again
    Call Back