NAME

Chart::GGPlot::Scale - The role for scale

VERSION

version 0.0002_01

ATTRIBUTES

aesthetics

The name of the aesthetics that this scale works with.

scale_name

The name of the scale.

palette

A palette function that when called with a single integer argument (the number of levels in the scale) returns the values that they should take.

limits

A numeric vector of length two providing limits of the scale.

name

Used as axis or legend title. If undef, the default, it's taken from the first mapping used for that aesthetic. If null or [], the legend title will be omitted.

breaks

One of

  • null or [] for no breaks.

  • undef for default breaks computed by the tranformation object.

  • a numeric vector of positions.

  • a function that takes the limits as input and returns breaks.

labels

One of

  • null or [] for no labels.

  • undef for default labels computed by the tranformation object.

  • a string vector of labels (must be same of length as breaks).

  • a function that takes the breaks as input and returns labels.

na_value

Missing values will be replaced with this value.

trans

Either the name of a transformation object, or the object itself. Built-in transformations include "asn", "atanh", "exp", "identity", "identity", "log", "log10", "log1p", etc. See Chart::GGPlot::Trans for details.

guide

A function used to create a guide or its name.

position

The position of the axis. Possible values are "left", "right", "top", "bottom".

METHODS

train_df($df)

Train scale from a dataframe. Adjust range of the scale according to column data.

reset()

Reset scale, untrain ranges.

transform_df

Returns an associative arrayref of transformed variables and their values.

map_df($df, $i=null)

This calls map_to_limits() on each of the scale's aesthetics. Returns an associative arrayref which maps aesthetics to processed column data.

map_to_limits($p, $limits=$self->get_limits)

Maps a piddle of data to the scale's limits. Returns a piddle of processed column data.

AUTHOR

Stephan Loyd <sloyd@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2019 by Stephan Loyd.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.