Carlos Pascual 23a46b5fb9
Add "left" and "right" step Modes (#1360)
* Add "lstep" and "rstep" step Modes

stepMode is currently either True or False. If it is True,
it requires the user to make len(x) = len(y)+1. This is
inconvenient because it makes it difficult to change the
stepMode on a given curve (just as one would change, e.g.,
its color).

This commit extends the current situation by introducing
two more step modes: "lstep" and "rstep", which do not require
passing an extra x value. In turn, this modes associate each
y value to either the left or the right boundary of the step.

For example, the "rstep" mode is handy when plotting "life"
digital signals in which x,y data pairs are appended as they
are read.

This commit does not modify the behaviour in case of stepMode=True

* Replace step mode names: lstep,rstep -> left,right

* Improve docs for stepMode

Reword docstring and add it to PlotDataItem class too

* Document left and right stepModes as added in v 0.12.0

TODO: confirm the exact version number to use here

* Add comments stress the need for "is True"

Some conditional statements in the code regarding stepMode are
done with "is True". This is actually required since other
possible values such as "left" also evaluate as true but should
not be caught.

* Deprecate boolean API for stepMode

Introduce stepMode="mid" as a replacement of stepMode=True,
but keeping full backwards compatibility with the old API.
Adapt docs, examples and tests accordingly.

* Raise ValueError on unsupported stepMode values

* Rename "mid" step mode to "center"

* Remove "added in 0.12.0" note

See https://github.com/pyqtgraph/pyqtgraph/pull/1360#discussion_r502746919

* Add deprecation warning when stepMode=True

Issue a DeprecationWarning if stepMode=True is being passed to the
constructor or setData() of PlotDataItem or PlotCurveItem.

Note: warnings module is imported locally so that it is esier to
remove once this check is no longer needed.

* Fix wrong syntax in last commit

Fix usage of "default" kwarg in dict.get()
2020-10-13 08:52:07 -07:00
..
2018-05-23 21:12:16 -07:00
2018-06-22 17:31:58 -07:00
2017-10-18 00:18:46 -07:00
2013-03-26 13:46:26 -04:00
2013-02-24 23:09:03 -05:00
2013-02-24 23:09:03 -05:00
2013-02-24 23:09:03 -05:00
2013-02-24 23:09:03 -05:00
2020-04-27 11:43:22 -07:00
2020-04-27 11:43:22 -07:00
2014-09-25 17:26:06 -04:00
2014-05-08 09:50:26 -04:00
2013-02-24 23:09:03 -05:00
2014-06-27 10:55:55 -04:00
2015-01-17 00:21:33 +08:00
2016-08-31 15:14:25 -07:00
2018-03-29 08:49:42 -07:00
2013-09-06 15:36:36 -04:00
2013-02-24 23:09:03 -05:00
2013-02-24 23:09:03 -05:00
2013-02-24 23:09:03 -05:00
2013-02-24 23:09:03 -05:00
2013-02-24 23:09:03 -05:00
2015-01-17 00:21:33 +08:00
2013-02-24 23:09:03 -05:00
2013-02-24 23:09:03 -05:00
2016-08-31 15:14:25 -07:00
2013-02-24 23:09:03 -05:00
2020-06-12 22:40:20 -07:00
2018-02-16 12:21:39 +08:00
2020-10-12 12:45:13 +02:00
2013-02-24 23:09:03 -05:00
2014-05-22 01:22:12 -04:00
2013-11-06 23:14:27 -05:00
2013-02-24 23:09:03 -05:00
2018-06-15 14:18:38 -07:00
2020-06-10 23:03:43 -07:00
2020-06-10 23:03:43 -07:00
2013-03-06 06:27:24 -05:00
2015-01-17 00:21:33 +08:00
2013-02-24 23:09:03 -05:00
2020-07-15 10:30:41 +02:00
2014-12-23 15:55:52 -05:00
2015-02-28 11:26:45 -05:00