Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Immediate Mode in Doodle Canvas #168

Open
wants to merge 44 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 13 commits
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
b46b037
Something
VOSID8 Jun 23, 2024
ac31aad
Formatting and undoing experimental changes
VOSID8 Jun 23, 2024
0deaf63
Edited name of the file
VOSID8 Jun 23, 2024
ed749d3
Implemeting dummy
VOSID8 Jun 23, 2024
6a95f8d
Removed junk code
VOSID8 Jun 25, 2024
739b907
Fixing Reified file
VOSID8 Jun 25, 2024
c52c5b6
Removing junk files
VOSID8 Jun 25, 2024
5418467
Removing junk files
VOSID8 Jun 25, 2024
9e05dcf
Changed type parameter to raster[A] to trait[A]
VOSID8 Jun 26, 2024
b22fabd
Changed type parameter to raster[A] to trait[A]
VOSID8 Jun 26, 2024
d882c6e
Removed junk file
VOSID8 Jun 26, 2024
d9c5745
Removed Raster from Image and added an experiment example
VOSID8 Jun 27, 2024
f4deb93
Removed Raster from Image and added an experiment example
VOSID8 Jun 27, 2024
879be92
Added Headers to 2 files
VOSID8 Jun 27, 2024
ce43de1
Adding 2nd parameter in example
VOSID8 Jun 27, 2024
7d53610
prePR formatted the code
VOSID8 Jun 27, 2024
4c4c4a6
Fix ScalaFix configuration
noelwelsh Jun 27, 2024
5b51b48
Fix raster syntax
noelwelsh Jun 27, 2024
300f5fa
Add raster syntax to JVM syntax
noelwelsh Jun 27, 2024
635298d
Organize imports
noelwelsh Jun 27, 2024
cab9c2f
Update workflows
noelwelsh Jun 27, 2024
57aa401
Merge pull request #1 from noelwelsh/canvasRaster
VOSID8 Jun 28, 2024
dada964
Changing Algrabra to something of combinator
VOSID8 Jun 30, 2024
5ab7c2c
Raster as constructor
VOSID8 Jul 1, 2024
eddca62
Added transformation to the Raster
VOSID8 Jul 3, 2024
a8be38b
Replacing Canvas Methods with Doodle's
VOSID8 Jul 10, 2024
4a1268a
Replacing Canvas Methods with Doodle's
VOSID8 Jul 10, 2024
8b9d0a3
Passing canvasContext as implicit
VOSID8 Jul 12, 2024
176c370
First working Immediate model
VOSID8 Jul 13, 2024
18c6a84
meh5
VOSID8 Jul 17, 2024
1fbc41f
Implemented few Immediate methods
VOSID8 Jul 18, 2024
826e35f
Added Methods for Immediate
VOSID8 Jul 24, 2024
52ddb09
fillColor to fill
VOSID8 Aug 2, 2024
acc8921
Methods added
VOSID8 Aug 7, 2024
7906eeb
Added text method
VOSID8 Aug 14, 2024
ad31840
Added dash Shapes and text
VOSID8 Aug 16, 2024
167b572
Added star
VOSID8 Aug 17, 2024
66ca336
Added canvasImmediate Landscape example and few fixes
VOSID8 Aug 17, 2024
ec3054a
Formatted the code
VOSID8 Aug 18, 2024
69b6150
GitWorkflowGenerate
VOSID8 Aug 18, 2024
30f91b4
Removed warnings
VOSID8 Aug 18, 2024
ced2f8e
Removed cmd /c from sbt file
VOSID8 Aug 18, 2024
24bc8c5
Few changes and example setup
VOSID8 Aug 20, 2024
37f2618
Fixed methods"
VOSID8 Aug 22, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -29,9 +29,11 @@ final case class CanvasAlgebra(
applyDrawing: Apply[CanvasDrawing] = Apply.apply[CanvasDrawing],
functorDrawing: Functor[CanvasDrawing] = Apply.apply[CanvasDrawing]
) extends Path,
Raster,
Shape,
GenericDebug[CanvasDrawing],
GenericLayout[CanvasDrawing],
GenericRaster[CanvasDrawing, CanvasRenderingContext2D],
GenericSize[CanvasDrawing],
GenericStyle[CanvasDrawing],
GenericTransform[CanvasDrawing],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,12 @@ object CanvasDrawing {
}
}

def raster(width: Int, height: Int)(
f: CanvasRenderingContext2D => Unit
): CanvasDrawing[Unit] = {
CanvasDrawing.raster(width, height)(f)
}

def setFill(fill: Option[Fill]): CanvasDrawing[Unit] =
fill.map(setFill).getOrElse(unit)

Expand Down
33 changes: 33 additions & 0 deletions canvas/src/main/scala/doodle/canvas/algebra/Raster.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
/*
* Copyright 2015 Creative Scala
*
* 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
*
* http://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.
*/

package doodle.canvas.algebra

import doodle.algebra.Algebra
import doodle.algebra.generic._
import org.scalajs.dom.CanvasRenderingContext2D


trait Raster extends GenericRaster[CanvasDrawing, CanvasRenderingContext2D] {
self: Algebra { type Drawing[U] = Finalized[CanvasDrawing, U] } =>

object RasterApi extends RasterApi {
def raster(width: Int, height: Int)(f: CanvasRenderingContext2D => Unit): CanvasDrawing[Unit] = {
CanvasDrawing.raster(width, height)(f)
}
}
}

2 changes: 1 addition & 1 deletion canvas/src/main/scala/doodle/canvas/algebra/Shape.scala
Original file line number Diff line number Diff line change
Expand Up @@ -70,4 +70,4 @@ trait Shape extends GenericShape[CanvasDrawing] {
def unit: CanvasDrawing[Unit] =
CanvasDrawing.unit
}
}
}
2 changes: 2 additions & 0 deletions core/js/src/main/scala/doodle/syntax/package.scala
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ package object syntax {
with LayoutSyntax
with NormalizedSyntax
with PathSyntax
with RasterSyntax
with RendererSyntax
with ShapeSyntax
with SizeSyntax
Expand All @@ -41,6 +42,7 @@ package object syntax {
object layout extends LayoutSyntax
object normalized extends NormalizedSyntax
object path extends PathSyntax
object raster extends RasterSyntax
object renderer extends RendererSyntax
object shape extends ShapeSyntax
object size extends SizeSyntax
Expand Down
34 changes: 34 additions & 0 deletions core/shared/src/main/scala/doodle/algebra/Raster.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
/*
* Copyright 2015 Creative Scala
*
* 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
*
* http://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.
*/

package doodle
package algebra

trait Raster[A] extends Algebra {
def raster(width: Int, height: Int)(f: A => Unit): Drawing[Unit]
}

trait RasterConstructor[A] {
self: BaseConstructor { type Algebra <: Raster[A] } =>

def raster(width: Int, height: Int)(f: A => Unit): Picture[Unit] =
new Picture[Unit] {
def apply(implicit algebra: Algebra): algebra.Drawing[Unit] =
algebra.raster(width, height)(f)
}
}


Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
package doodle
package algebra
package generic

import cats.data.State
import doodle.core.BoundingBox

trait GenericRaster[G[_], A] extends Raster[A] {
self: Algebra { type Drawing[U] = Finalized[G, U] } =>

trait RasterApi {
def raster(width: Int, height: Int)(f: A => Unit): G[Unit]
}

def RasterApi: RasterApi

def raster(width: Int, height: Int)(f: A => Unit): Finalized[G, Unit] = {
Finalized.leaf { dc =>
val bb = BoundingBox.centered(width, height)
(
bb,
State.inspect(_ => RasterApi.raster(width, height)(f))
)
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -94,4 +94,4 @@ trait GenericShape[G[_]] extends Shape {
Finalized.leaf { _ =>
(BoundingBox.empty, Renderable.unit(ShapeApi.unit))
}
}
}
16 changes: 16 additions & 0 deletions core/shared/src/main/scala/doodle/syntax/RasterSyntax.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package doodle
VOSID8 marked this conversation as resolved.
Show resolved Hide resolved
package syntax

import doodle.algebra.Picture
import doodle.algebra.Raster

trait RasterSyntax {
def raster[Alg <: Raster[A], A](
width: Int,
height: Int
)(f: A => Unit): Picture[Alg, Unit] =
new Picture[Alg, Unit] {
def apply(implicit algebra: Alg): algebra.Drawing[Unit] =
algebra.raster(width, height)(f)
}
}
3 changes: 3 additions & 0 deletions docs/src/pages/svg/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -61,3 +61,6 @@ The source for these examples is [in the repository](https://github.com/creative

### Parametric Spiral
@:doodle("parametric-spiral", "SvgParametricSpiral.draw")

### Experimenting
@:doodle("Experiment", "Experiment.draw")
Original file line number Diff line number Diff line change
Expand Up @@ -37,4 +37,4 @@ object ConcentricCircles {
@JSExport
def draw(mount: String) =
circles(7).drawWithFrame(Frame(mount))
}
}
36 changes: 36 additions & 0 deletions examples/js/src/main/scala/doodle/examples/canvas/Experiment.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
/*
* Copyright 2015 Creative Scala
*
* 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
*
* http://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.
*/

package doodle.examples.canvas

import cats.effect.unsafe.implicits.global
import doodle.canvas.{*, given}
import doodle.core.*
import doodle.syntax.all.*

import scala.scalajs.js.annotation.*

@JSExportTopLevel("Experiment")
object Experiment {
def rect1 = Picture.rectangle(100, 100).fillColor(Color.red)
def rect2 = Picture.rectangle(100, 100).fillColor(Color.blue)

val joint = rect1.beside(rect2).raster(10,20)
VOSID8 marked this conversation as resolved.
Show resolved Hide resolved

@JSExport
def draw(mount: String) =
joint.drawWithFrame(Frame(mount))
}
2 changes: 1 addition & 1 deletion image/shared/src/main/scala/doodle/image/Image.scala
Original file line number Diff line number Diff line change
Expand Up @@ -238,7 +238,7 @@ object Image {
Circle(diameter)

def pie(diameter: Double, angle: Angle): Image =
path(doodle.core.ClosedPath.pie(0.0, 0.0, diameter, angle))
path(doodle.core.ClosedPath.pie(0.0, 0.0, diameter, angle))

def rectangle(width: Double, height: Double): Image =
Rectangle(width, height)
Expand Down
Loading