Welcome to PubNub's collaboration demo where you can draw with others in real-time.
This is a multi-user drawing web application built using PubNub's real-time network JavaScript API, Canvas, and vanilla JavaScript/HTML/CSS. No other libraries or frameworks are necessary.
You can draw with others connected to the application and see these results on their screen in real-time. The connected users' mice movements are tracked as they are drawing and moving around the canvas, and includes a text bubble that showcases a user-input name that is updated in real-time across all user instances.
- Users can draw and see each others' artwork update in real-time.
- Mouse movements are also tracked in real-time, so users can see the mouse movements of all those connected.
- Each user connected can type in a name, which appears under their stylus mouse. The names can be updated and will be updated in real-time.
- Clear your screen, or clear everyone's screen, by pressing on the waste basket icons.
- The number of users connected is tracked and updated in the top right-corner of the screen by making use of Presence detection.
Try the application!
If you would like to build, run, and expand upon this application yourself, please follow the sections below. There is also a detailed tutorial on how this applciation was built located on PubNub's website.
- Git
- Your favorite IDE or code editor, such as Visual Studio Code.
- PubNub Account (Free)
- Sign in to your PubNub Dashboard. You are now in the Admin Portal.
- Go to Apps using the left-hand side navigation.
- Click the Create New App button in the top-right of the Portal.
- Give your app a name.
- Click Create.
- Click your new app to open its settings.
- When you create a new app, the first set of keys are generated automatically. However, a single app can have as many keysets as you like. PubNub recommends that you create separate keysets for production and test environments.
- Click on the keyset.
- Enable two features for the keyset to be able to connect to the PubNub Network: Presence and Stream Controller.
- Enable Presence by clicking on the slider to turn it on. A pop-up will require that you enter in “ENABLE”. Enter in “ENABLE” in all caps and then press the “Enable” button. Enable the "Generate Leave on TCP FIN or RST checkbox", which generates leave events when clients close their connection (used to track occupancy and remove non-connected clients in app). You can leave the rest of the default settings.
- Enable Stream Controller by clicking on the slider to turn it on if it is already not enabled. You can leave the default settings.
- Click on save changes.
- Save the Publish and Subscribe Keys.
-
Clone the GitHub repository.
git clone https://github.com/PubNubDevelopers/collaboration-demo.git
-
Navigate to the folder, and open the js/app.js file.
-
Replace your publish and subscribe keys with the PUBLISH_KEY and SUBSCRIBE_KEY constants at the top of the file.
-
Open the index.html file in a browser. Enter in your name, move the mouse to see your name tracked with you.
-
Draw by holding down left click while moving.
-
Clear your screen by clicking on the top left waste basket icon.
-
Clear everyone's screen by clicking on the bottom left waste basket icon.
-
Open
index.html
in a new tab to have a new user join the drawing channel. -
You can see their mouse movements and drawings in real-time. The occupancy count also reflects the users in the channel.
Note: You may have also seen a variant of this application on the PubNub homepage. The source code that drives that app is the same that drives the demo described above, but there are some styling and logic changes applied, as configured by homepage.html
, constants_homepage.js
and style_homepage.css
- Demo Link: https://www.pubnub.com/demos/codoodler-collaboration-demo/
- Tutorial Link: https://www.pubnub.com/tutorials/collaboration/
- How-To create collaborative applications:
- Blog post on collaborative applications:
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
https://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.