Is there a Javascript library for Paint-like appli

2019-03-09 01:02发布

问题:

Is there a Javascript library which has built-in features for quickly creating a Paint-like web application using the canvas element?

EDIT: So, far, I have found Javascript libraries that allow easy animation of canvas elements -- such as Raphael JS -- and Javascript tutorials for creating simple Paint apps, but no robust libraries for Paint-like applications.

EDIT 2: I found a Javascript tutorial on a pretty nice looking Paint app using the canvas element. I'd still like to see what others have found.

回答1:

There is processingJS, but as it is port of the JAVA bassed processing you write your code in "javaish" processing language. But after all you could create what an paint like app. Another framework is fabricJS which is also really great to work with canvas.



回答2:

Raphaël

Raphaël doesn't use Canvas. It uses SVG on browsers that support it or VML on Internet Explorer.

SVG

If you want an SVG solution designed specifically for drawing then take a look at:

  • SVG-edit

See this demo.

Canvas

If you want to use Canvas but you need a retained mode rendering then see:

  • Fabric.js
  • Paper.js
  • Processing.js
  • EaselJS
  • KineticJS
  • bHive

Update (February 2014)

  • ART, a retained mode vector drawing API - targets all three of HTML5 Canvas, SVG and VML (plus some code generation). Used by the Facebook team together with the React UI toolkit (see: react-art and the "art" branch of the react-page project on GitHub).


回答3:

Literally Canvas fits this exact purpose: http://literallycanvas.com

"Literally Canvas is an extensible, open source (BSD-licensed), HTML5 drawing widget...You can use it to embed drawing boards in web pages."



回答4:

You can try painterro. It can be used for pasting and processing screenshots, cropping, drawing primitives and text, rotating and resizing (changing resolution)



回答5:

I think the closest you'll get is to expand on what that tutorial has gone through.

It's hard to create "general purpose" paint-like functionality due to the wide range of requirements.



回答6:

There is an npm package spainter.

Live Demo