# JKQtPlotter: Examples: Examples & Tutorials
This section assembles some simple examples of usage.
You can find more (complex) examples for the classes in this repository in the subfolder "test".
All test-projects are Qt-projects that use qmake to build. You can load them into QtCreator easily.
## Different Plot Data Styles
| Screenshot | Description | Notes |
|:-------------:| ------------- | ------------- |
| [data:image/s3,"s3://crabby-images/65f64/65f64d8e3ee211dc1bc264418caa719937fcf48f" alt=""](./simpletest) | [Very Basic Example (Line Graph)](./simpletest) | `JKQTPxyLineGraph`
C++-style QVector arrays of data |
| [data:image/s3,"s3://crabby-images/c38fd/c38fdac256f37e21e0c8a40b4560b56cebd64f27" alt=""](./simpletest_speed) | [Line Graph with Live Data / Speed Test](./simpletest_speed) | `JKQTPxyLineGraph`
external `std::array` data, not owned by datastore
live-data, measure plotting speed
tipps to increas plotting speed |
| [data:image/s3,"s3://crabby-images/46b00/46b00606a0774d0fe7d7aa63e5921df6e95cccf1" alt=""](./simpletest_symbols_and_styles) | [Line Graph with Different Symbols and Line Styles](./simpletest_symbols_and_styles) | `JKQTPxyLineGraph`
C++ vector of data
setting line styles and symbol styles
automatic graph coloring |
| [data:image/s3,"s3://crabby-images/fcb1c/fcb1c65569e8efa7153870bee84b8776308e754d" alt=""](./simpletest_stepplots) | [Step Line Plots in Different Styles](./simpletest_stepplots) | `JKQTPstepHorizontalGraph` (and `JKQTPxyLineGraph`)
C++ vector of data
different step modes, filled and line-only |
| [data:image/s3,"s3://crabby-images/fd66a/fd66a136d5768f4fa4aac8871b5ff8117d2bee79" alt=""](./simpletest_symbols_and_errors) | [Simple Line/Symbol Graph With Errorbars](./simpletest_symbols_and_errors) | `JKQTPxyLineErrorGraph`
C-style arrays of data |
| [data:image/s3,"s3://crabby-images/8ba89/8ba8914f657ba46587879f1aba5e4cd842bf3398" alt=""](./simpletest_errorbarstyles) | [Different Types of Error Indicators](./simpletest_errorbarstyles) | `JKQTPxyLineErrorGraph`
different styles of error indicators for x- and y-errors
C++-style QVector for data
styling error indicators
moving key and formatting plotter grid |
| [data:image/s3,"s3://crabby-images/6c77f/6c77fd0115a28062d3f0bdb908bec1f840ae9d66" alt=""](./simpletest_barchart) | [Simple Bar Charts](./simpletest_barchart) | `JKQTPbarVerticalGraph`
C-style arrays of data |
| [data:image/s3,"s3://crabby-images/87da6/87da6c2917c82efff00e819c7a165aedefc0c69f" alt=""
data:image/s3,"s3://crabby-images/ed42d/ed42d9698d1a6b4f57a4a2c26fefba0333896c9e" alt=""](./simpletest_stackedbars) | [Stacked Bar Charts](./simpletest_stackedbars) | `JKQTPbarVerticalStackableGraph`, `JKQTPbarHorizontalStackableGraph`
C++-style vectors of data |
| [data:image/s3,"s3://crabby-images/e26fb/e26fbe3a27e45a83faed026da635bbfd7edd7b8e" alt=""](./simpletest_filledgraphs) | [Filled Curve Plots](./simpletest_filledgraphs) | `JKQTPbarVerticalGraph`
setting/altering data in `JKQTPdatstore` directly
transparent plots
calculating histograms |
| [data:image/s3,"s3://crabby-images/cfc05/cfc05c39d5657c55fe1592b64ee914fcce6fe685" alt=""](./simpletest_impulsesplot) | [Impulse Plots](./simpletest_impulsesplot) | `JKQTPimpulsesVerticalGraph` and `JKQTPimpulsesHorizontalGraph`
C++-style QVector as plot data |
| [data:image/s3,"s3://crabby-images/8d3c5/8d3c51e940df6901a78288ce70557faf7b2a8d5e" alt=""](./simpletest_paramscatterplot) | [Scatter Graph with Parametrized Symbols/Colors](./simpletest_paramscatterplot) | `JKQTPxyParametrizedScatterGraph`
C++-style QVector as plot data
modify scatter/points/line-graph properties by data |
| [data:image/s3,"s3://crabby-images/53643/536432f3eb4e53bf6bf1fe3ee08fdda4e6077145" alt=""](./simpletest_paramscatterplot_image) | [Draw an Artistic Image with a Parametrized Scatter Graph](./simpletest_paramscatterplot_image) | `JKQTPxyParametrizedScatterGraph`
C++-style QVector as plot data
rectangular arrangement of scatters
generative computer graphics |
| [data:image/s3,"s3://crabby-images/64bfe/64bfee93727a4a0d68750d30abfc3f9a662c6fd9" alt=""](./simpletest_parametriccurve) | [Plotting Parametric Curves](./simpletest_parametriccurve) | `JKQTPxyLineGraph` and `JKQTPxyParametrizedScatterGraph`
C++-style QVector as plot data
parametric curve plotting |
| [data:image/s3,"s3://crabby-images/6c497/6c4976dcaadabec6e040e5c6f1455c9f0d3d4408" alt=""](./simpletest_functionplot) | [Plotting Mathematical Functions as Line Graphs](./simpletest_functionplot) | `JKQTPxFunctionLineGraph`
diretly plotting C/C++-functions |
| [data:image/s3,"s3://crabby-images/33187/331873a8030a0af91e0c8f3c10be729b12d53331" alt=""](./simpletest_parsedfunctionplot) | [Plotting Parsed Mathematical Functions as Line Graphs](./simpletest_parsedfunctionplot) | `JKQTPxParsedFunctionLineGraph`
plotting functions with the internal math equation parser/evaluator |
| [data:image/s3,"s3://crabby-images/555ad/555ad0dd02de33b564bcf6c3d3dbe24564b85d89" alt=""](./simpletest_geometric) | [Plotting Geometric Objects](./simpletest_geometric) | |
## Styling the Plot, Keys, Axes, ...
| Screenshot | Description | Notes |
|:-------------:| ------------- | ------------- |
| [data:image/s3,"s3://crabby-images/686dd/686dd5b53f756f9306c40347c6ce25c382671ff2" alt=""](./simpletest_logaxes) | [logarithmic axes](./simpletest_logaxes) | `JKQTPxyLineGraph` and `JKQTPgeoText`
C++ vector of data
logarithmic axes and styling
plot line styles
internal LaTeX parser
add commenting text to a graph |
| [data:image/s3,"s3://crabby-images/b26e8/b26e8034a1dc4432ce681172669dced7136f40d6" alt=""
data:image/s3,"s3://crabby-images/51269/512692b4c6be2224124fd8eac13fefa5fff9517c" alt=""
data:image/s3,"s3://crabby-images/c19b6/c19b66d3b1e6b29e5a7ff5c9121f0445765b3284" alt=""](./simpletest_dateaxes) | [date/time axes](./simpletest_dateaxes) | `JKQTPxyLineGraph` and `JKQTPfilledVerticalRangeGraph`
C++ vector of data
date/time axes
plot min/max range graph
internal LaTeX parser
data from CSV files |
## Image data Plots
| Screenshot | Description | Notes |
|:-------------:| ------------- | ------------- |
| [data:image/s3,"s3://crabby-images/51e7e/51e7e2eada7c31e6bc766326294e997f55c290e8" alt=""](./simpletest_rgbimageplot_qt) | [`QImage` as a Graph](./simpletest_rgbimageplot_qt) | `JKQTPImage`
`QImage` drawn onto a plot with arbitrary scaling) |
| [data:image/s3,"s3://crabby-images/faece/faeceab6c3ca9673c33ab056e7ca1418e6a352f6" alt=""](./simpletest_imageplot) | [Basic 1-channel Raw C Image Plot](./simpletest_imageplot) | `JKQTPColumnMathImage`
image data copied from C-style row-major array into a single column of the internal datastore
Describes several options of the image plotting classes (different ways of color coding, what to do with data above/below the limits etc.) |
| [data:image/s3,"s3://crabby-images/fa124/fa124cfa035ff1928ab4e9bd4e02ba5497734db7" alt=""](./simpletest_imageplot_modifier) | [Modifier-Feature of Image Plots](./simpletest_imageplot_modifier) | `JKQTPColumnMathImage`
image data copied from C-style row-major array into a single column of the internal datastore
Image is modified by a second image to display two data dimensions at the same time |
| [data:image/s3,"s3://crabby-images/d30d3/d30d3c4853b499135888838093fe1d5173ac413a" alt=""](./simpletest_imageplot_nodatastore) | [Basic 1-channel Raw C Image Plot
without the internal datastore](./simpletest_imageplot_nodatastore) | `JKQTPMathImage`
image data in a C-style row-major array, not using internal datastore |
| [data:image/s3,"s3://crabby-images/69896/698962ff39d7df51e8fa97de72442eb0a13fc86b" alt=""](./simpletest_imageplot_opencv) | [1-channel OpenCV cv::Mat Image Plot](./simpletest_imageplot_opencv) | `JKQTPColumnMathImage`
image data copied from OpenCV cv::Mat-structure into a single column of the internal datastore |
| [data:image/s3,"s3://crabby-images/1b2e7/1b2e7caf76b772f514ae022f2d49f7ae35af0556" alt=""](./simpletest_rgbimageplot_opencv) | [RGB OpenCV cv::Mat Image Plot](./simpletest_rgbimageplot_opencv) | `JKQTPColumnRGBMathImage`
image data copied from OpenCV cv::Mat-structure into three columns of the internal datastore |
## GUI Tools and Plot Layout
| Screenshot | Description | Notes |
|:-------------:| ------------- | ------------- |
| [data:image/s3,"s3://crabby-images/f7649/f764914fe15aad1c426d95bcfe086cdf41a8a931" alt=""](./test_multiplot) | [Layouting Several Plots](./test_multiplot) | Combining plots in Qt Layouts
linking plot axes
copy data from a `std::map` int the datastore
print plots/print preview |
| [data:image/s3,"s3://crabby-images/2040a/2040aa2412e0be5430d3b01ae47e7641f404e6f3" alt=""](./simpletest_ui) | [Placing JKQtPlotter into a Qt User-Interface-XML-file (`*.ui`)](./simpletest_ui) | using Qt Form Designer
parsed function plots (`JKQTPxParsedFunctionLineGraph`) |
## Tools and Special Features
| Screenshot | Description | Notes |
|:-------------:| ------------- | ------------- |
| [data:image/s3,"s3://crabby-images/16e63/16e63b0df21ace94863f9f8d494fa854697e5455" alt=""](./jkqtmathtext_simpletest) | [JKQTMathText: LaTeX Renderer](./jkqtmathtext_simpletest) | |