Class HexaSparseGridPortrayal2D

All Implemented Interfaces:
Portrayal, Portrayal2D

public class HexaSparseGridPortrayal2D extends SparseGridPortrayal2D
Portrayal for hexagonal grids (each cell has six equally-distanced neighbors). It can draw either continuous and descrete sparse fields. The 'location' passed into the DrawInfo2D handed to the SimplePortryal2D is an Int2D.
  • Constructor Details

    • HexaSparseGridPortrayal2D

      public HexaSparseGridPortrayal2D()
    • HexaSparseGridPortrayal2D

      public HexaSparseGridPortrayal2D(DrawPolicy policy)
      Deprecated.
      Use setDrawPolicy.
  • Method Details

    • setObjectLocation

      public void setObjectLocation(Object object, Object location, GUIState gui)
      Description copied from class: FieldPortrayal
      Sets location in the underlying field of the given object, if such a thing is reasonable. Largely used for setObjectPosition(...), and in the Inspector's LocationWrapper via the Stable classes. Optionally overridable. The default implementation does nothing.
      Overrides:
      setObjectLocation in class SparseGridPortrayal2D
    • getScale

      public Double2D getScale(DrawInfo2D info)
      Description copied from class: FieldPortrayal2D
      Returns the width and height, in pixels, of 1.0 x 1.0 units in the underlying field. Optionally overridable. The default version thows an error if called.
      Overrides:
      getScale in class SparseGridPortrayal2D
    • getPositionLocation

      public Object getPositionLocation(Point2D.Double position, DrawInfo2D info)
      Description copied from class: FieldPortrayal2D
      Returns the Location, in the parlance of the underlying Field, of the given position. If there is no such Location, then null is returned. Optionally overridable. By default null is returned.
      Overrides:
      getPositionLocation in class SparseGridPortrayal2D
    • getLocationPosition

      public Point2D.Double getLocationPosition(Object location, DrawInfo2D info)
      Description copied from class: FieldPortrayal2D
      Returns the position on-screen of the provided location in the underlying field. Negative positions are acceptable. If null is returned, then the portrayal is unable to perform the requested action on the given location. Optionally overridable. The default implementation returns null.
      Overrides:
      getLocationPosition in class SparseGridPortrayal2D
    • hitOrDraw

      protected void hitOrDraw(Graphics2D graphics, DrawInfo2D info, Bag putInHere)
      Description copied from class: FieldPortrayal2D
      Instead of overriding the draw and hitObjects methods, you can optionally override this method to provide both the draw(...) and hitObjects(...) functionality in a single method, as it's common that these two methods have nearly identical code. You should test which operation to do based on whether or not graphics is null (if it is, you're hitting, else you're drawing).
      Overrides:
      hitOrDraw in class SparseGridPortrayal2D
    • setBorder

      public void setBorder(boolean on)
      This is not supported by hexagonal portrayals. Throws an exception.
      Overrides:
      setBorder in class SparseGridPortrayal2D
    • setGridLines

      public void setGridLines(boolean on)
      This is not supported by hexagonal portrayals. Throws an exception.
      Overrides:
      setGridLines in class SparseGridPortrayal2D