three.js VS p5.js

Compare three.js vs p5.js and see what are their differences.

p5.js

p5.js is a client-side JS platform that empowers artists, designers, students, and anyone to learn to code and express themselves creatively on the web. It is based on the core principles of Processing. http://twitter.com/p5xjs — (by processing)
SurveyJS - Open-Source JSON Form Builder to Create Dynamic Forms Right in Your App
With SurveyJS form UI libraries, you can build and style forms in a fully-integrated drag & drop form builder, render them in your JS app, and store form submission data in any backend, inc. PHP, ASP.NET Core, and Node.js.
surveyjs.io
featured
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
three.js p5.js
454 236
99,250 20,929
- 0.8%
9.9 9.9
4 days ago 7 days ago
JavaScript JavaScript
MIT License GNU Lesser General Public License v3.0 only
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

three.js

Posts with mentions or reviews of three.js. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-05-05.
  • I've made game engine (I think)
    2 projects | dev.to | 5 May 2024
    Hi! With Python and ThreeJS (https://threejs.org/) I have made app to make easy 3d visualisation, which you can test in browser. Like this:
  • Implementing 3D Graphics in React
    6 projects | dev.to | 3 May 2024
    In React, there are different libraries for rendering 3D. In this article, we will focus on how to use the Three.js Library, React Three Fiber library, and the React Three Drei library for creating 3D objects.
  • Implementing Bloom Effect with Mapbox and Three.js
    3 projects | dev.to | 8 Apr 2024
    Regarding the optimization of the effect, I found an issue on the three.js GitHub repository: https://github.com/mrdoob/three.js/issues/14104 The alpha channel issue seems to be a difficult problem, which has been present since 2018. At the end of the discussion, a solution proposed by a contributor is not to modify the UnrealBloomPass but to blend the source texture and target texture in the shader.
  • Finding Stars and Affirmations in the Sky with Three.js for Ayra Starr
    2 projects | dev.to | 1 Apr 2024
    Here's how we used Three.js to place and find affirmations in the sky.
  • Ask HN: Tips to get started on my own server
    19 projects | news.ycombinator.com | 25 Mar 2024
  • Incredible JavaScript Animation Libraries
    6 projects | dev.to | 24 Mar 2024
    Three.js is dedicated to generating 3D visuals, offering a powerful suite of features and tools. It is built atop WebGL and optimizes GPU usage for rapid rendering, ensuring smooth performance across devices, including those with limited resources. Three.js's versatility allows for the creation of a vast spectrum of 3D graphics and animations, ranging from simple shapes to intricate models.
  • JavaScript Libraries That You Should Know
    8 projects | dev.to | 19 Mar 2024
    7. three.js
  • React: A Mess That Shouldn't Exist In Web Development
    3 projects | dev.to | 9 Mar 2024
    Most of frontend libraries are made with Vanilla JS. An example of library that you might frequently use is "Chart.js". But React is not compatible with Chart.js so here it comes "React-chartjs-2" A wrapper library to work with Chart.js in React ecosystem. Oh you want to use "three.js" for some cool 3D? you will need "React-three/fiber". In my case, I need to implement "telegram-web-app", not so fast, I have to create my own wrapper to be able to use it.
  • JPEG XL Is a Stupid Name
    1 project | news.ycombinator.com | 5 Mar 2024
  • Things you should know before learning Three.js
    1 project | dev.to | 4 Feb 2024
    For one of my 100-Day Challenges, I chose to dive into Three.js, a JavaScript 3D library. It's easy to start learning, and it becomes difficult to master with the inclusion of shaders.

p5.js

Posts with mentions or reviews of p5.js. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-11-30.
  • P5.js: Online Canvas Programming
    1 project | news.ycombinator.com | 27 Feb 2024
  • Coming Home From the South Pole
    1 project | news.ycombinator.com | 10 Jan 2024
  • Turbo Pascal Turns 40
    8 projects | news.ycombinator.com | 30 Nov 2023
    Processing (P5) had this: you can select any string of text in its IDE anl search for it in the docs, and if it's one of the built-in functions or constants it will open the associated static html page that came installed with the software, so no internet nor server required. And despite being offline you can still navigate the docs too. This feels a lost basic skill in static site generation these days.

    It was the only creative coding framework that had complete, offline documentation like that at the time I might add. OpenFrameworks is still mostly autogenerated stubs for example.

    IMO it was one of the things that gave Processing an edge in educational contexts over all alternatives. I was pretty sad to see p5.js not fully continue that tradition and require that you go online to read the docs, and that it's not a static website but that text is rendered with javascript when you open it (still complete and with examples though).

    https://processing.org/

    https://p5js.org/

  • My Google Play Developer account has been terminated
    1 project | news.ycombinator.com | 15 Oct 2023
    I thought it could be funny to use the javascript version of it https://p5js.org/ in a web page and then wrap it in a Unity app, since Unity was and is the environment I use for making apps.
  • Repetition can make you loopy!: Intro to JavaScript Loops
    1 project | dev.to | 14 Aug 2023
    In this last section, I'll be creating some visual examples to show how helpful loops can be. I'll be using p5js, a JavaScript library with functionality for creative coding. That being said, I'll try to give a condensed version of the functions being utilized in the following examples.
  • G9.js: Automatically Interactive Graphics
    2 projects | news.ycombinator.com | 8 Aug 2023
    I was curious too, took a little bit of digging :)

    "the original domain of [P]rocessing was proce55ing.net, so people used to sometimes refer to processing as proce55ing or P5 or p5 for short. they still do sometimes. p5.js is a reference to that."

    from https://github.com/processing/p5.js/issues/2443

  • [OC] Monthly Performance of the S&P 500: 94 Years in 1 Video.
    1 project | /r/dataisbeautiful | 27 Jun 2023
    Sketch.js - https://p5js.org/
  • Ask HN: How to teach a kid of 15 Linux and programming
    3 projects | news.ycombinator.com | 20 Jun 2023
    > how do I get him learning programming in a fun way?

    Processing / P5.js can be pretty fun to learn. You use a real programming language to create art and animations. With little code you can get a circle on the screen, then making it move, then following your mouse, then adding other shapes, then changing colour depending on some event… It’s conductive to experimentation and a way to gradually introduce concepts.

    https://processing.org/

    https://p5js.org/

    https://thecodingtrain.com/

  • [OC] I created a simple, free waveform and genre visualizer for your top ten Spotify songs, a few samples below and link to the tool in the comments!
    1 project | /r/dataisbeautiful | 8 Jun 2023
    Then I used p5js to create the 'art' itself, really user friendly coding framework with lots of resources online! If you want to get into coding, that is a really great entry point with Daniel Schiffman's coding train videos on YT!
  • Different texture types
    1 project | /r/p5js | 28 May 2023
    Posted an issue for it that u guys can check out here: https://github.com/processing/p5.js/issues/6166

What are some alternatives?

When comparing three.js and p5.js you can also consider the following projects:

BabylonJS - Babylon.js is a powerful, beautiful, simple, and open game and rendering engine packed into a friendly JavaScript framework.

paper.js - The Swiss Army Knife of Vector Graphics Scripting – Scriptographer ported to JavaScript and the browser, using HTML5 Canvas. Created by @lehni & @puckey

model-viewer - Easily display interactive 3D models on the web and in AR!

fabric.js - Javascript Canvas Library, SVG-to-Canvas (& canvas-to-SVG) Parser

heatmap.js - 🔥 JavaScript Library for HTML5 canvas based heatmaps

two.js - A renderer agnostic two-dimensional drawing api for the web.

A-Frame - :a: Web framework for building virtual reality experiences.

framer/motion - Open source, production-ready animation and gesture library for React

Konva - Konva.js is an HTML5 Canvas JavaScript framework that extends the 2d context by enabling canvas interactivity for desktop and mobile applications.