src/Tools/Graphview/shapes.scala
author wenzelm
Sat, 02 Apr 2016 14:17:03 +0200
changeset 62812 ce22e5c3d4ce
parent 60215 5fb4990dfc73
child 73340 0ffcad1f6130
permissions -rw-r--r--
more robust display of bidirectional Unicode text: enforce left-to-right;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
59202
711c2446dc9d clarified source location;
wenzelm
parents: 50479
diff changeset
     1
/*  Title:      Tools/Graphview/shapes.scala
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     2
    Author:     Markus Kaiser, TU Muenchen
59240
e411afcfaa29 tuned headers;
wenzelm
parents: 59236
diff changeset
     3
    Author:     Makarius
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     4
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     5
Drawable shapes.
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     6
*/
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     7
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     8
package isabelle.graphview
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     9
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    10
59245
be4180f3c236 more formal Graph_Display.Node (with ordering) and Graph_Display.Edge;
wenzelm
parents: 59242
diff changeset
    11
import isabelle._
be4180f3c236 more formal Graph_Display.Node (with ordering) and Graph_Display.Edge;
wenzelm
parents: 59242
diff changeset
    12
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    13
import java.awt.{BasicStroke, Graphics2D, Shape}
59410
19f396384cbe tuned colors;
wenzelm
parents: 59407
diff changeset
    14
import java.awt.geom.{AffineTransform, GeneralPath, Path2D, Rectangle2D,
19f396384cbe tuned colors;
wenzelm
parents: 59407
diff changeset
    15
  RoundRectangle2D, PathIterator}
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    16
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    17
50467
wenzelm
parents: 50464
diff changeset
    18
object Shapes
wenzelm
parents: 50464
diff changeset
    19
{
59249
wenzelm
parents: 59248
diff changeset
    20
  private val default_stroke =
wenzelm
parents: 59248
diff changeset
    21
    new BasicStroke(1, BasicStroke.CAP_BUTT, BasicStroke.JOIN_ROUND)
wenzelm
parents: 59248
diff changeset
    22
59384
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    23
  def shape(info: Layout.Info): Rectangle2D.Double =
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    24
    new Rectangle2D.Double(info.x - info.width2, info.y - info.height2, info.width, info.height)
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    25
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    26
  def highlight_node(gfx: Graphics2D, graphview: Graphview, node: Graph_Display.Node)
59410
19f396384cbe tuned colors;
wenzelm
parents: 59407
diff changeset
    27
  {
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    28
    val metrics = graphview.metrics
59410
19f396384cbe tuned colors;
wenzelm
parents: 59407
diff changeset
    29
    val extra = metrics.char_width
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    30
    val info = graphview.layout.get_node(node)
59410
19f396384cbe tuned colors;
wenzelm
parents: 59407
diff changeset
    31
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    32
    gfx.setColor(graphview.highlight_color)
59410
19f396384cbe tuned colors;
wenzelm
parents: 59407
diff changeset
    33
    gfx.fill(new Rectangle2D.Double(
19f396384cbe tuned colors;
wenzelm
parents: 59407
diff changeset
    34
      info.x - info.width2 - extra,
19f396384cbe tuned colors;
wenzelm
parents: 59407
diff changeset
    35
      info.y - info.height2 - extra,
19f396384cbe tuned colors;
wenzelm
parents: 59407
diff changeset
    36
      info.width + 2 * extra,
19f396384cbe tuned colors;
wenzelm
parents: 59407
diff changeset
    37
      info.height + 2 * extra))
19f396384cbe tuned colors;
wenzelm
parents: 59407
diff changeset
    38
  }
19f396384cbe tuned colors;
wenzelm
parents: 59407
diff changeset
    39
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    40
  def paint_node(gfx: Graphics2D, graphview: Graphview, node: Graph_Display.Node)
50467
wenzelm
parents: 50464
diff changeset
    41
  {
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    42
    val metrics = graphview.metrics
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    43
    val info = graphview.layout.get_node(node)
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    44
    val c = graphview.node_color(node)
59384
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    45
    val s = shape(info)
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    46
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    47
    gfx.setColor(c.background)
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    48
    gfx.fill(s)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    49
59384
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    50
    gfx.setColor(c.border)
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    51
    gfx.setStroke(default_stroke)
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    52
    gfx.draw(s)
59236
346aada8eb53 clarified metrics, similar to old graph browser;
wenzelm
parents: 59231
diff changeset
    53
59384
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    54
    gfx.setColor(c.foreground)
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    55
    gfx.setFont(metrics.font)
59242
fda4091cc6b0 prefer integer coordinates;
wenzelm
parents: 59241
diff changeset
    56
59384
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    57
    val text_width =
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    58
      (0.0 /: info.lines) { case (w, line) => w max metrics.string_bounds(line).getWidth }
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    59
    val text_height =
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    60
      (info.lines.length max 1) * metrics.height.ceil
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    61
    val x = (s.getCenterX - text_width / 2).round.toInt
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    62
    var y = (s.getCenterY - text_height / 2 + metrics.ascent).round.toInt
62812
ce22e5c3d4ce more robust display of bidirectional Unicode text: enforce left-to-right;
wenzelm
parents: 60215
diff changeset
    63
    for (line <- info.lines) {
ce22e5c3d4ce more robust display of bidirectional Unicode text: enforce left-to-right;
wenzelm
parents: 60215
diff changeset
    64
      gfx.drawString(Word.bidi_override(line), x, y)
ce22e5c3d4ce more robust display of bidirectional Unicode text: enforce left-to-right;
wenzelm
parents: 60215
diff changeset
    65
      y += metrics.height.ceil.toInt
ce22e5c3d4ce more robust display of bidirectional Unicode text: enforce left-to-right;
wenzelm
parents: 60215
diff changeset
    66
    }
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    67
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    68
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    69
  def paint_dummy(gfx: Graphics2D, graphview: Graphview, info: Layout.Info)
50467
wenzelm
parents: 50464
diff changeset
    70
  {
59384
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    71
    gfx.setStroke(default_stroke)
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    72
    gfx.setColor(graphview.dummy_color)
59384
c75327a34960 more explicit Layout.Info: size and content;
wenzelm
parents: 59303
diff changeset
    73
    gfx.draw(shape(info))
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    74
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    75
59248
167c2ebdfab4 tuned signature;
wenzelm
parents: 59245
diff changeset
    76
  object Straight_Edge
50467
wenzelm
parents: 50464
diff changeset
    77
  {
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    78
    def paint(gfx: Graphics2D, graphview: Graphview, edge: Graph_Display.Edge)
50464
37b53813426f tuned signature;
wenzelm
parents: 49745
diff changeset
    79
    {
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    80
      val p = graphview.layout.get_node(edge._1)
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    81
      val q = graphview.layout.get_node(edge._2)
50468
7a2a4b84c5ee tuned min/max;
wenzelm
parents: 50467
diff changeset
    82
      val ds =
7a2a4b84c5ee tuned min/max;
wenzelm
parents: 50467
diff changeset
    83
      {
59262
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
    84
        val a = p.y min q.y
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
    85
        val b = p.y max q.y
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    86
        graphview.layout.dummies_iterator(edge).filter(d => a < d.y && d.y < b).toList
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    87
      }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    88
      val path = new GeneralPath(Path2D.WIND_EVEN_ODD, ds.length + 2)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    89
59262
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
    90
      path.moveTo(p.x, p.y)
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
    91
      ds.foreach(d => path.lineTo(d.x, d.y))
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
    92
      path.lineTo(q.x, q.y)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    93
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    94
      if (graphview.show_dummies) ds.foreach(paint_dummy(gfx, graphview, _))
50467
wenzelm
parents: 50464
diff changeset
    95
59250
wenzelm
parents: 59249
diff changeset
    96
      gfx.setStroke(default_stroke)
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
    97
      gfx.setColor(graphview.edge_color(edge, p.y < q.y))
59250
wenzelm
parents: 59249
diff changeset
    98
      gfx.draw(path)
50467
wenzelm
parents: 50464
diff changeset
    99
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
   100
      if (graphview.show_arrow_heads) Arrow_Head.paint(gfx, path, Shapes.shape(q))
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   101
    }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   102
  }
50467
wenzelm
parents: 50464
diff changeset
   103
59248
167c2ebdfab4 tuned signature;
wenzelm
parents: 59245
diff changeset
   104
  object Cardinal_Spline_Edge
50467
wenzelm
parents: 50464
diff changeset
   105
  {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   106
    private val slack = 0.1
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   107
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
   108
    def paint(gfx: Graphics2D, graphview: Graphview, edge: Graph_Display.Edge)
50464
37b53813426f tuned signature;
wenzelm
parents: 49745
diff changeset
   109
    {
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
   110
      val p = graphview.layout.get_node(edge._1)
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
   111
      val q = graphview.layout.get_node(edge._2)
50468
7a2a4b84c5ee tuned min/max;
wenzelm
parents: 50467
diff changeset
   112
      val ds =
7a2a4b84c5ee tuned min/max;
wenzelm
parents: 50467
diff changeset
   113
      {
59262
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   114
        val a = p.y min q.y
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   115
        val b = p.y max q.y
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
   116
        graphview.layout.dummies_iterator(edge).filter(d => a < d.y && d.y < b).toList
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   117
      }
50467
wenzelm
parents: 50464
diff changeset
   118
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
   119
      if (ds.isEmpty) Straight_Edge.paint(gfx, graphview, edge)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   120
      else {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   121
        val path = new GeneralPath(Path2D.WIND_EVEN_ODD, ds.length + 2)
59262
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   122
        path.moveTo(p.x, p.y)
50467
wenzelm
parents: 50464
diff changeset
   123
59262
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   124
        val coords = p :: ds ::: List(q)
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   125
        val dx = coords(2).x - coords(0).x
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   126
        val dy = coords(2).y - coords(0).y
50467
wenzelm
parents: 50464
diff changeset
   127
wenzelm
parents: 50464
diff changeset
   128
        val (dx2, dy2) =
59262
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   129
          ((dx, dy) /: coords.sliding(3)) {
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   130
            case ((dx, dy), List(l, m, r)) =>
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   131
              val dx2 = r.x - l.x
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   132
              val dy2 = r.y - l.y
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   133
              path.curveTo(
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   134
                l.x + slack * dx, l.y + slack * dy,
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   135
                m.x - slack * dx2, m.y - slack * dy2,
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   136
                m.x, m.y)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   137
              (dx2, dy2)
59262
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   138
          }
50467
wenzelm
parents: 50464
diff changeset
   139
59262
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   140
        val l = ds.last
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   141
        path.curveTo(
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   142
          l.x + slack * dx2, l.y + slack * dy2,
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   143
          q.x - slack * dx2, q.y - slack * dy2,
5cd92c743958 explicit Layout.Point;
wenzelm
parents: 59258
diff changeset
   144
          q.x, q.y)
50467
wenzelm
parents: 50464
diff changeset
   145
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
   146
        if (graphview.show_dummies) ds.foreach(paint_dummy(gfx, graphview, _))
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   147
59250
wenzelm
parents: 59249
diff changeset
   148
        gfx.setStroke(default_stroke)
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
   149
        gfx.setColor(graphview.edge_color(edge, p.y < q.y))
59250
wenzelm
parents: 59249
diff changeset
   150
        gfx.draw(path)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   151
59459
985fc55e9f27 clarified module name;
wenzelm
parents: 59410
diff changeset
   152
        if (graphview.show_arrow_heads) Arrow_Head.paint(gfx, path, Shapes.shape(q))
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   153
      }
50467
wenzelm
parents: 50464
diff changeset
   154
    }
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   155
  }
50467
wenzelm
parents: 50464
diff changeset
   156
wenzelm
parents: 50464
diff changeset
   157
  object Arrow_Head
wenzelm
parents: 50464
diff changeset
   158
  {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   159
    type Point = (Double, Double)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   160
50467
wenzelm
parents: 50464
diff changeset
   161
    private def position(path: GeneralPath, shape: Shape): Option[AffineTransform] =
wenzelm
parents: 50464
diff changeset
   162
    {
wenzelm
parents: 50464
diff changeset
   163
      def intersecting_line(path: GeneralPath, shape: Shape): Option[(Point, Point)] =
wenzelm
parents: 50464
diff changeset
   164
      {
49745
083accbfa77d more conventional Double constants;
wenzelm
parents: 49742
diff changeset
   165
        val i = path.getPathIterator(null, 1.0)
59245
be4180f3c236 more formal Graph_Display.Node (with ordering) and Graph_Display.Edge;
wenzelm
parents: 59242
diff changeset
   166
        val seg = Array[Double](0.0, 0.0, 0.0, 0.0, 0.0, 0.0)
49745
083accbfa77d more conventional Double constants;
wenzelm
parents: 49742
diff changeset
   167
        var p1 = (0.0, 0.0)
083accbfa77d more conventional Double constants;
wenzelm
parents: 49742
diff changeset
   168
        var p2 = (0.0, 0.0)
60215
5fb4990dfc73 misc tuning, based on warnings by IntelliJ IDEA;
wenzelm
parents: 59459
diff changeset
   169
        while (!i.isDone) {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   170
          i.currentSegment(seg) match {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   171
            case PathIterator.SEG_MOVETO => p2 = (seg(0), seg(1))
50467
wenzelm
parents: 50464
diff changeset
   172
            case PathIterator.SEG_LINETO =>
wenzelm
parents: 50464
diff changeset
   173
              p1 = p2
wenzelm
parents: 50464
diff changeset
   174
              p2 = (seg(0), seg(1))
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   175
50467
wenzelm
parents: 50464
diff changeset
   176
              if(shape.contains(seg(0), seg(1)))
wenzelm
parents: 50464
diff changeset
   177
                return Some((p1, p2))
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   178
            case _ =>
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   179
          }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   180
          i.next()
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   181
        }
50467
wenzelm
parents: 50464
diff changeset
   182
        None
wenzelm
parents: 50464
diff changeset
   183
      }
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   184
50467
wenzelm
parents: 50464
diff changeset
   185
      def binary_search(line: (Point, Point), shape: Shape): Option[AffineTransform] =
wenzelm
parents: 50464
diff changeset
   186
      {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   187
        val ((fx, fy), (tx, ty)) = line
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   188
        if (shape.contains(fx, fy) == shape.contains(tx, ty))
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   189
          None
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   190
        else {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   191
          val (dx, dy) = (fx - tx, fy - ty)
49745
083accbfa77d more conventional Double constants;
wenzelm
parents: 49742
diff changeset
   192
          if ((dx * dx + dy * dy) < 1.0) {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   193
            val at = AffineTransform.getTranslateInstance(fx, fy)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   194
            at.rotate(- (math.atan2(dx, dy) + math.Pi / 2))
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   195
            Some(at)
50467
wenzelm
parents: 50464
diff changeset
   196
          }
wenzelm
parents: 50464
diff changeset
   197
          else {
49745
083accbfa77d more conventional Double constants;
wenzelm
parents: 49742
diff changeset
   198
            val (mx, my) = (fx + (tx - fx) / 2.0, fy + (ty - fy) / 2.0)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   199
            if (shape.contains(fx, fy) == shape.contains(mx, my))
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   200
              binary_search(((mx, my), (tx, ty)), shape)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   201
            else
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   202
              binary_search(((fx, fy), (mx, my)), shape)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   203
          }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   204
        }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   205
      }
50467
wenzelm
parents: 50464
diff changeset
   206
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   207
      intersecting_line(path, shape) match {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   208
        case None => None
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   209
        case Some(line) => binary_search(line, shape)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   210
      }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   211
    }
50467
wenzelm
parents: 50464
diff changeset
   212
59250
wenzelm
parents: 59249
diff changeset
   213
    def paint(gfx: Graphics2D, path: GeneralPath, shape: Shape)
50464
37b53813426f tuned signature;
wenzelm
parents: 49745
diff changeset
   214
    {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   215
      position(path, shape) match {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   216
        case None =>
50479
de02116c34fa less massive arrow heads;
wenzelm
parents: 50475
diff changeset
   217
        case Some(at) =>
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   218
          val arrow = new GeneralPath(Path2D.WIND_EVEN_ODD, 3)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   219
          arrow.moveTo(0, 0)
50479
de02116c34fa less massive arrow heads;
wenzelm
parents: 50475
diff changeset
   220
          arrow.lineTo(-10, 4)
de02116c34fa less massive arrow heads;
wenzelm
parents: 50475
diff changeset
   221
          arrow.lineTo(-6, 0)
de02116c34fa less massive arrow heads;
wenzelm
parents: 50475
diff changeset
   222
          arrow.lineTo(-10, -4)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   223
          arrow.lineTo(0, 0)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   224
          arrow.transform(at)
59250
wenzelm
parents: 59249
diff changeset
   225
          gfx.fill(arrow)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   226
      }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   227
    }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   228
  }
60215
5fb4990dfc73 misc tuning, based on warnings by IntelliJ IDEA;
wenzelm
parents: 59459
diff changeset
   229
}