Writing to a File
An Image can be written to a file as well as displaying it on screen. The file formats you can write depend on the backend you're using:
- the Java2D backend can write PDF, PNG, GIF, and JPEG; and
- the SVG backend running on the JVM can write SVG; but
- the SVG backend running in the web browser cannot write files.
Most people will use the Java2D backend and the examples below show use this backend.
Imports
In addition to the usual imports of
import doodle.image._
import doodle.image.syntax.all._
import doodle.core._
to write to a file you'll need
import doodle.java2d._
import doodle.core.format._
import cats.effect.unsafe.implicits.global
The first import pulls in the Java2D backend. The second import makes available the standard formats supported by Doodle. The third import brings in the Cats Effect runtime, needed to run code.
Writing an Image
Call the write
method to write to a file, giving the format as a type parameter and the file name as a normal parameter. For example, to write a PNG to the file called "circle.png"
val image = Image.circle(100)
.strokeWidth(10.0)
.fillColor(Color.crimson)
image.write[Png]("circle.png")
Instead of using Png
you could use Gif
or Jpg
to specify those file formats. You'd probably want to change the file name as well if you change the format. That's it! Your masterpiece is now ready to share with the world.