Class CellLatticeOSX

java.lang.Object
org.opensourcephysics.display.Grid
org.opensourcephysics.display2d.CellLatticeOSX
All Implemented Interfaces:
Drawable, Measurable, ByteLattice, CellLattice.OSLattice

public class CellLatticeOSX extends Grid implements Measurable, CellLattice.OSLattice
A Mac version of CellLattice that displays an array where each array element can assume one of 256 values. Early versions of Java on Mac OSX were not able to set pixels in an image raster. This class implements an alternate CellLattice that does not use an image raster. Values can be set between -128 and 127. Because byte values larger than 127 overflow to negative, values can also be set between 0 and 255. The lattice is drawn as an array of rectangles to distinguish between the two possible values.
Version:
1.0
Author:
Wolfgang Christian, Joshua Gould
  • Constructor Details

    • CellLatticeOSX

      public CellLatticeOSX(int nx, int ny)
      Constructs a Cell lattice with the given size. Site values are -128 to 127.
      Parameters:
      nx - sites in x dirction
      ny - sites in y direction
  • Method Details

    • createSiteLattice

      public SiteLattice createSiteLattice()
      Creates a new SiteLattice containing the same data as this lattice.
      Specified by:
      createSiteLattice in interface CellLattice.OSLattice
    • resizeLattice

      public void resizeLattice(int _nx, int _ny)
      Description copied from interface: ByteLattice
      Resizes the lattice.
      Specified by:
      resizeLattice in interface ByteLattice
    • getNx

      public int getNx()
      Gets the number of x entries.
      Specified by:
      getNx in interface ByteLattice
      Returns:
      nx
    • getNy

      public int getNy()
      Gets the number of y entries.
      Specified by:
      getNy in interface ByteLattice
      Returns:
      ny
    • indexFromPoint

      public int indexFromPoint(double x, double y)
      Determines the lattice index (row-major order) from given x and y world coordinates Returns -1 if the world coordinates are outside the lattice.
      Specified by:
      indexFromPoint in interface ByteLattice
      Parameters:
      x -
      y -
      Returns:
      index
    • xToIndex

      public int xToIndex(double x)
      Gets closest index from the given x world coordinate.
      Specified by:
      xToIndex in interface ByteLattice
      Parameters:
      x - double the coordinate
      Returns:
      int the index
    • yToIndex

      public int yToIndex(double y)
      Gets closest index from the given y world coordinate.
      Specified by:
      yToIndex in interface ByteLattice
      Parameters:
      y - double the coordinate
      Returns:
      int the index
    • setVisible

      public void setVisible(boolean isVisible)
      Sets the visibility of the lattice. Drawing will be disabled if visible is false.
      Specified by:
      setVisible in interface ByteLattice
      Overrides:
      setVisible in class Grid
      Parameters:
      isVisible -
    • draw

      public void draw(DrawingPanel panel, Graphics g)
      Draws the lattice and the grid.
      Specified by:
      draw in interface Drawable
      Overrides:
      draw in class Grid
      Parameters:
      panel -
      g -
    • setBlock

      public void setBlock(int ix_offset, int iy_offset, byte[][] val)
      Sets a block of cells using byte values.
      Specified by:
      setBlock in interface ByteLattice
      Parameters:
      ix_offset - int
      iy_offset - int
      val - byte[][]
    • setAll

      public void setAll(byte[][] val)
      Sets a block of data to new values. The lattice is resized to fit the new data if needed.
      Parameters:
      val -
    • setAll

      public void setAll(byte[][] val, double xmin, double xmax, double ymin, double ymax)
      Sets the lattice values and scale. The lattice is resized to fit the new data if needed.
      Specified by:
      setAll in interface ByteLattice
      Parameters:
      val - int[][] the new values
      xmin - double
      xmax - double
      ymin - double
      ymax - double
    • setBlock

      public void setBlock(int ix_offset, int iy_offset, int[][] val)
      Sets a block of cells using integer values.
      Specified by:
      setBlock in interface CellLattice.OSLattice
      Parameters:
      ix_offset - int
      iy_offset - int
      val - int[][]
    • setBlock

      public void setBlock(byte[][] val)
      Sets a block of cells to new values.
      Specified by:
      setBlock in interface ByteLattice
      Parameters:
      val -
    • setCol

      public void setCol(int ix, int iy_offset, byte[] val)
      Sets a column to new values.
      Specified by:
      setCol in interface ByteLattice
      Parameters:
      ix - the x index of the column
      iy_offset - the y offset in the column
      val - values in column
    • setRow

      public void setRow(int iy, int ix_offset, byte[] val)
      Sets a row to new values.
      Specified by:
      setRow in interface ByteLattice
      Parameters:
      iy - the y index of the row
      ix_offset - the x offset in the row
      val -
    • setValue

      public void setValue(int ix, int iy, byte val)
      Sets the given x,y location to a new value.
      Specified by:
      setValue in interface ByteLattice
      Parameters:
      ix -
      iy -
      val -
    • getValue

      public byte getValue(int col, int row)
      Gets a lattice site value.
      Specified by:
      getValue in interface ByteLattice
      Parameters:
      row -
      col -
      Returns:
      the cell value.
    • setShowVisible

      public void setShowVisible(boolean isVisible)
      Sets the visibility of the sites. Drawing will be disabled if visible is false.
      Parameters:
      isVisible -
    • setShowGridLines

      public void setShowGridLines(boolean showGridLines)
      Sets the visibility of the grid connecting the sites.
      Specified by:
      setShowGridLines in interface ByteLattice
      Parameters:
      showGridLines -
    • randomize

      public void randomize()
      Randomizes the lattice values.
      Specified by:
      randomize in interface ByteLattice
    • showLegend

      public JFrame showLegend()
      Shows the color associated with each value.
      Specified by:
      showLegend in interface ByteLattice
      Returns:
      the JFrame containing the legend
    • setColorPalette

      public void setColorPalette(Color[] _colors)
      Sets the color palette.
      Specified by:
      setColorPalette in interface ByteLattice
      Parameters:
      _colors -
    • setGridLineColor

      public void setGridLineColor(Color _color)
      Sets the grid line color.
      Specified by:
      setGridLineColor in interface ByteLattice
      Parameters:
      _color -
    • setIndexedColor

      public void setIndexedColor(int i, Color color)
      Sets the color for a single index.
      Specified by:
      setIndexedColor in interface ByteLattice
      Parameters:
      i -
      color -
    • isMeasured

      public boolean isMeasured()
      Method isMeasured
      Specified by:
      isMeasured in interface Measurable
      Returns:
    • setXMin

      public void setXMin(double _value)
      Description copied from interface: ByteLattice
      Sets xmin.
      Specified by:
      setXMin in interface ByteLattice
      Parameters:
      _value - double
    • setXMax

      public void setXMax(double _value)
      Description copied from interface: ByteLattice
      Sets xmax.
      Specified by:
      setXMax in interface ByteLattice
      Parameters:
      _value - double
    • setYMin

      public void setYMin(double _value)
      Description copied from interface: ByteLattice
      Sets ymin.
      Specified by:
      setYMin in interface ByteLattice
      Parameters:
      _value - double
    • setYMax

      public void setYMax(double _value)
      Description copied from interface: ByteLattice
      Sets ymax.
      Specified by:
      setYMax in interface ByteLattice
      Parameters:
      _value - double
    • createDefaultColors

      public void createDefaultColors()
      Creates the default palette.
      Specified by:
      createDefaultColors in interface ByteLattice