May 12, 2024   -   David Oyinbo

Canvas Gravity Balls

Pet project for HTML Canvas and JavaScript—simulating gravity, bounce, and simple collisions across multiple balls.

JavaScriptHTML CanvasPhysicsAnimationPet Project
canvas infinity and circle mouse image

Overview

This experiment uses Canvas 2D APIs to render and animate circles influenced by gravity with basic collision and bounce behavior. It focuses on animation loops, simple physics, and interaction.

Highlights

Physics

  • Gravity and velocity integration
  • Bounce with restitution (elasticity)
  • Basic wall collision handling

Canvas Rendering

  • Efficient clear + redraw loop
  • Responsive canvas sizing
  • Minimal draw calls

Interaction

  • Mouse clicks to spawn balls
  • Adjustable gravity/restitution (in code)
  • Smooth motion via requestAnimationFrame

Footprint

  • No dependencies
  • Small, hackable codebase
  • Great for learning Canvas + physics basics

Other Projects

October 1, 2021

Payaza Web SDK

A JavaScript Web SDK that simplifies integrating Payaza checkout on web applications. Built as part of my role at Payaza Africa.

SDKJavaScriptPayments
January 22, 2025

Auth module for Nuxt server apps

Auth module for Nuxt 3 server apps with local and social providers, tokens, middlewares, and typed composables.

TypeScriptNuxt 3Auth
May 10, 2024

Canvas Random Floating Circle

Pet project animating randomly floating circles on HTML Canvas with simple drift and easing.

JavaScriptHTML CanvasAnimation

Let's build something together

Available for senior engineering roles, consulting, and architecture reviews.

© 2025 David Oyinbo