Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ably-labs/collaborative-pixel-drawing
A collaborative pixelart drawing carnvas to demonstrate pub/sub using Ably or Azure WebPubSub.
https://github.com/ably-labs/collaborative-pixel-drawing
ably azure-functions demo dotnet javascript pubsub serverless websocket
Last synced: about 1 month ago
JSON representation
A collaborative pixelart drawing carnvas to demonstrate pub/sub using Ably or Azure WebPubSub.
- Host: GitHub
- URL: https://github.com/ably-labs/collaborative-pixel-drawing
- Owner: ably-labs
- License: apache-2.0
- Created: 2022-07-05T10:33:34.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-09-04T12:25:24.000Z (over 1 year ago)
- Last Synced: 2024-04-17T15:32:35.891Z (8 months ago)
- Topics: ably, azure-functions, demo, dotnet, javascript, pubsub, serverless, websocket
- Language: JavaScript
- Homepage: https://pixel-paint.ably.dev/
- Size: 518 KB
- Stars: 1
- Watchers: 7
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Collaborative pixelart drawing
![Screenshot](/media/collaborative-pixelart-drawing.gif)
## Description
This repository contains an example how to synchronize state in realtime between many client devices using serverless WebSockets (Ably or Azure Web PubSub). The context of the example is a collaborative drawing canvas that multiple people can use at the same time to draw pixelart. The code in this repo is used in the blog post [Cloud pubsub services compared: Azure Web PubSub vs Ably](https://ably.com/blog/cloud-pubsub-services-compared-azure-web-pubsub-ably?utm_source=github&utm_medium=repo&utm_campaign=collaborative-pixelart-drawing).
This repository contains two implementations of the same project:
- The [`main` branch](https://github.com/ably-labs/collaborative-pixel-drawing) of this repo contains the implementation using Ably.
- The [`azure-web-pubsub` branch](https://github.com/ably-labs/collaborative-pixel-drawing/tree/azure-web-pubsub) contains the implementation using Azure Web PubSub.> This repository also contains a [CodeTour](https://code.visualstudio.com/learn/educators/codetour) for each of these branches, which you can use to navigate the code when you're using VSCode. You will be asked to download the CodeTour extension when you open the folder.
## Tech stack
This project uses the following components:
- [p5js](https://p5js.org/); A creative coding library, used for the drawing canvas.
- [Ably](https://ably.com?utm_campaign=GLB-2208-collaborative-pixel-drawing&utm_content=repo-collaborative-pixel-drawing&utm_source=github&utm_medium=repo&src=GLB-2208-collaborative-pixel-drawing-github); A realtime messaging platform, used as the serverless WebSockets component.
- [Azure Functions](https://docs.microsoft.com/azure/azure-functions/functions-overview); A serverless compute service from Microsoft Azure.
- [Azure Static Web Apps](https://docs.microsoft.com/azure/static-web-apps/overview); An Azure service for hosting static websites.![Pubsub with Ably](media/Pubsub-ably-1.png)
The `src` folder contains the front-end files which are based on vanilla JavaScript and [p5js](https://p5js.org/).
The `api` folder contains a .NET 6 based Azure Function App with the following functions:
- `ChangeColorPalette`; returns a color palette based on the paletteId that is provided.
- `CreateTokenRequest`; provides an authentication token and is triggered when a connection to Ably is made via the front-end.## Building & running locally
### Prerequisites
You require the following dependencies to run the solution locally:
- [.NET 6 SDK](https://dotnet.microsoft.com/download/dotnet/6.0). The .NET SDK required for the C# Azure Functions.
- [Node 16](https://nodejs.org/en/). The JavaScript runtime required to install Azure Static WebApps CLI.
- [Azure Static Web Apps CLI](https://github.com/Azure/static-web-apps-cli). This is the command line interface to develop and deploy Azure Static Web Apps. Install this tool globally by running this command in the terminal: `npm install -g @azure/static-web-apps-cli`.
- [Azure Functions Core Tools](https://docs.microsoft.com/azure/azure-functions/functions-run-local?tabs=v4%2Cwindows%2Ccsharp%2Cportal%2Cbash). This is part of the Azure Functions extensions for VSCode that should be recommended for installation when this repo is opened in VSCode.
- [Sign up](https://ably.com/signup?utm_campaign=GLB-2208-collaborative-pixel-drawing&utm_content=repo-collaborative-pixel-drawing&utm_source=github&utm_medium=repo&src=GLB-2208-collaborative-pixel-drawing-github) for a free Ably Account, [create a new app, and copy the API key](https://faqs.ably.com/setting-up-and-managing-api-keys?utm_campaign=GLB-2208-collaborative-pixel-drawing&utm_content=repo-collaborative-pixel-drawing&utm_source=github&utm_medium=repo&src=GLB-2208-collaborative-pixel-drawing-github).### Building the project
1. Clone or fork this repo.
2. Rename the `api\local.settings.json.example` file to `api\local.settings.json`.
3. Copy/paste the Ably API key in the `ABLY_APIKEY` field in the `local.settings.json` file.
4. Run `swa start` in the root folder.The local Static Web App should be available at `http://localhost:4280`.
## Contributing
Want to help contributing to this project? Have a look at our [contributing guide](CONTRIBUTING.md)!
## More info
- [Join our Discord server](http://go.ably.com/discord)
- [Follow us on Twitter](https://twitter.com/ablyrealtime)
- [Use our SDKs](https://github.com/ably/)
- [Visit our website](https://ably.com?utm_campaign=GLB-2208-collaborative-pixel-drawing&utm_content=repo-collaborative-pixel-drawing&utm_source=github&utm_medium=repo&src=GLB-2208-collaborative-pixel-drawing-github)---
[![Ably logo](https://static.ably.dev/badge-black.svg?collaborative-pixelart-drawing)](https://ably.com?utm_campaign=GLB-2208-collaborative-pixel-drawing&utm_content=repo-collaborative-pixel-drawing&utm_source=github&utm_medium=repo&src=GLB-2208-collaborative-pixel-drawing-github)