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

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
February 19, 2026

Trypema Rate Limiter

High-performance Rust rate limiting primitives with local and Redis-backed providers, atomic Redis enforcement, and absolute/suppressed strategies.

RustRate LimitingRedis
May 13, 2024

Canvas Infinity & Circle Mouse

Pet project exploring HTML Canvas and JavaScript animations—drawing an infinity curve and a circle following the mouse.

JavaScriptHTML CanvasAnimation

Let's build something together

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

© 2026 David Oyinbo