Maintainer | diagrams-discuss@googlegroups.com |
---|
Alignment combinators specialized for two dimensions. See Diagrams.Align for more general alignment combinators.
The basic idea is that alignment is achieved by moving diagrams'
local origins relative to their bounding regions. For example, to
align several diagrams along their tops, we first move their local
origins to the upper edge of their bounding regions (using
e.g. map
), and then put them together with their local
origins along a horizontal line (using e.g. alignTop
hcat
from
Diagrams.TwoD.Combinators).
- alignL :: (HasOrigin a, Boundable a, V a ~ R2) => a -> a
- alignR :: (HasOrigin a, Boundable a, V a ~ R2) => a -> a
- alignT :: (HasOrigin a, Boundable a, V a ~ R2) => a -> a
- alignB :: (HasOrigin a, Boundable a, V a ~ R2) => a -> a
- alignTL :: (HasOrigin a, Boundable a, V a ~ R2) => a -> a
- alignTR :: (HasOrigin a, Boundable a, V a ~ R2) => a -> a
- alignBL :: (HasOrigin a, Boundable a, V a ~ R2) => a -> a
- alignBR :: (HasOrigin a, Boundable a, V a ~ R2) => a -> a
- alignX :: (HasOrigin a, Boundable a, V a ~ R2) => Rational -> a -> a
- alignY :: (HasOrigin a, Boundable a, V a ~ R2) => Rational -> a -> a
- centerX :: (HasOrigin a, Boundable a, V a ~ R2) => a -> a
- centerY :: (HasOrigin a, Boundable a, V a ~ R2) => a -> a
- centerXY :: (HasOrigin a, Boundable a, V a ~ R2) => a -> a
Absolute alignment
alignL :: (HasOrigin a, Boundable a, V a ~ R2) => a -> aSource
Align along the left edge, i.e. translate the diagram in a horizontal direction so that the local origin is on the left edge of the bounding region.
Relative alignment
alignX :: (HasOrigin a, Boundable a, V a ~ R2) => Rational -> a -> aSource
alignX
moves the local origin horizontally as follows:
-
alignX (-1)
moves the local origin to the left edge of the bounding region; -
align 1
moves the local origin to the right edge; - any other argument interpolates linearly between these. For
example,
alignX 0
centers,alignX 2
moves the origin one "radius" to the right of the right edge, and so on.
alignY :: (HasOrigin a, Boundable a, V a ~ R2) => Rational -> a -> aSource
Like alignX
, but moving the local origin vertically, with an
argument of 1
corresponding to the top edge and (-1)
corresponding
to the bottom edge.
Centering
centerX :: (HasOrigin a, Boundable a, V a ~ R2) => a -> aSource
Center the local origin along the X-axis.