Giter Site home page Giter Site logo

MacGifer

No Maintenance Intended

In a divided world, streaming formats are a matter of inclusion. GIF was introduced by CompuServe in 1987, they didn't know how powerful it was going to be. 26 years later, using NodeJS together with Redis, WebRTC, websockets, webworkers and HTML5, MacGifer introduces GIF-based streaming, making it possible for Internet Explorer 6.0 to be part of society once again.

Requirements

# Redis
sudo add-apt-repository ppa:chris-lea/redis-server
sudo apt-get update
sudo apt-get install redis-server

Deploying

# using the included script
./deploy nko

How does it work?

        Browser                      Node.js                  Browser/phone
     (broadcaster)                    server                mplayer/microwave
           .                            .                       (watcher)
           |                            |                           .
           |--.                         |                           |
           |  | Get webcam frame        |<--------------------------|
           |  | (WebRTC)                |--.     HTTP Request       |
           |<-`                         |  |                        |
           |--.                         |  | Encode GIF header      |
           |  | Draw on                 |  | (GIFEncoder)           |
           |  | HTML5 canvas            |  |                        |
           |<-`                         |<-`                        |
           |--.                         |-------------------------->|
           |  | Apply                   |       Write header        |
           |  | extensions              |        to response        |
           |<-`                         |                           |
           |--.                         |                           |
           |  | Encode frame            |                           |
           |  | (GIFEncoder)            |                           |
           |<-`                         |                           |
           |--------------------------->|--.                        |
           |         Send frame         |  | Publish to             |
           |        (websockets)        |  | Redis channel          |
           |                            |<-`                        |
           |                            |--.                        |
           |                            |  | Read from              |
           |                            |  | Redis channel          |
           |                            |<-`                        |
           |                            |-------------------------->|
           |                            |       Write frame         |
           |                            |       to response         |
           |                            |                           |
           `                            `                           `

Authors

Credits and Thanks

  • The authors of GIFEncoder.js, LZWEncoder.js and NeuQuant.js
  • This project was created for the Node.js Knockout

License

MacGifer is Copyright (c) 2017 sophilabs, inc. It is free software, and may be redistributed under the terms specified in the license file.

About

sophilabs.co

MacGifer is maintained and funded by sophilabs, inc. The names and logos for sophilabs are trademarks of sophilabs, inc.

Sophilabs's Projects

dev-on-production icon dev-on-production

The main objetive of this project/talk is to introduce on using isolated environments for multiple devs, projects and machines.

djangoboot icon djangoboot

Site for starproject, startapp and cookiecutter templates.

draws icon draws

Take a file containing comma separated values and pick a winner in a stylish way

gilp icon gilp

Gilp: A node tool to implement pre-commit and other git hooks over gulp

hiring icon hiring

We are looking for a passionate and highly detail oriented developer who wants to join a team of happy geeks.

jsconfuy-jup icon jsconfuy-jup

Meteor sample application based on "You can't javascript under pressure"

learnregex icon learnregex

A pyschool story for learning regular expressions.

macgifer icon macgifer

MacGifer - Almost Realtime GIF-based Streaming

pullreq-ml icon pullreq-ml

A machine learning experiment for predicting Pull Requests acceptance rate

py101 icon py101

A pyschool story for learning Python Basics.

pyuy icon pyuy

Uruguayan Python Users Group Site

slack-asap icon slack-asap

⚡️ zap: Slack ASAP is *a* command to notify about things as soon as possible.

slack-quiet icon slack-quiet

🗣 Slack Quiet is a slash command to ask for silence in the workplace

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.