immerse final fixes and examples
192
docs/immerse_examples.md
Normal file
@ -0,0 +1,192 @@
|
||||
### Lines
|
||||
|
||||
A simple line plot of the 3 columns.
|
||||
|
||||
```julia
|
||||
plot(rand(100,3))
|
||||
```
|
||||
|
||||

|
||||
|
||||
### Functions
|
||||
|
||||
Plot multiple functions.
|
||||
|
||||
```julia
|
||||
plot(0:0.01:4π,[sin,cos])
|
||||
```
|
||||
|
||||

|
||||
|
||||
###
|
||||
|
||||
You can also call it with plot(f, xmin, xmax).
|
||||
|
||||
```julia
|
||||
plot([sin,cos],0,4π)
|
||||
```
|
||||
|
||||

|
||||
|
||||
###
|
||||
|
||||
Or make a parametric plot with plot(fx, fy, umin, umax).
|
||||
|
||||
```julia
|
||||
plot(sin,(x->begin # /home/tom/.julia/v0.4/Plots/docs/example_generation.jl, line 33:
|
||||
sin(2x)
|
||||
end),0,2π)
|
||||
```
|
||||
|
||||

|
||||
|
||||
### Global
|
||||
|
||||
Change the guides/background without a separate call.
|
||||
|
||||
```julia
|
||||
plot(rand(10); title="TITLE",xlabel="XLABEL",ylabel="YLABEL",background_color=RGB(0.5,0.5,0.5))
|
||||
```
|
||||
|
||||

|
||||
|
||||
### Two-axis
|
||||
|
||||
Use the `axis` or `axiss` arguments.
|
||||
|
||||
Note: This is only supported with Qwt right now
|
||||
|
||||
```julia
|
||||
plot(Vector[randn(100),randn(100) * 100]; axiss=[:left,:right],ylabel="LEFT",yrightlabel="RIGHT")
|
||||
```
|
||||
|
||||

|
||||
|
||||
### Vectors w/ pluralized args
|
||||
|
||||
Plot multiple series with different numbers of points. Mix arguments that apply to all series (singular... see `marker`) with arguments unique to each series (pluralized... see `colors`).
|
||||
|
||||
```julia
|
||||
plot(Vector[rand(10),rand(20)]; marker=:ellipse,markersize=8,colors=[:red,:blue])
|
||||
```
|
||||
|
||||

|
||||
|
||||
### Build plot in pieces
|
||||
|
||||
Start with a base plot...
|
||||
|
||||
```julia
|
||||
plot(rand(100) / 3; reg=true,fillto=0)
|
||||
```
|
||||
|
||||

|
||||
|
||||
###
|
||||
|
||||
and add to it later.
|
||||
|
||||
```julia
|
||||
scatter!(rand(100); markersize=6,color=:blue)
|
||||
```
|
||||
|
||||

|
||||
|
||||
### Heatmaps
|
||||
|
||||
|
||||
|
||||
```julia
|
||||
heatmap(randn(10000),randn(10000); nbins=100)
|
||||
```
|
||||
|
||||

|
||||
|
||||
### Lots of line types
|
||||
|
||||
Options: (:line, :step, :stepinverted, :sticks, :dots, :none, :heatmap, :hexbin, :hist, :bar)
|
||||
Note: some may not work with all backends
|
||||
|
||||
```julia
|
||||
plot(rand(20,4); linetypes=[:line,:step,:sticks,:dots],labels=["line","step","sticks","dots"])
|
||||
```
|
||||
|
||||

|
||||
|
||||
### Lots of line styles
|
||||
|
||||
Options: (:solid, :dash, :dot, :dashdot, :dashdotdot)
|
||||
Note: some may not work with all backends
|
||||
|
||||
```julia
|
||||
plot(rand(20,5); linestyles=[:solid,:dash,:dot,:dashdot,:dashdotdot],labels=["solid","dash","dot","dashdot","dashdotdot"])
|
||||
```
|
||||
|
||||

|
||||
|
||||
### Lots of marker types
|
||||
|
||||
Options: (:none, :ellipse, :rect, :diamond, :utriangle, :dtriangle, :cross, :xcross, :star1, :star2, :hexagon)
|
||||
Note: some may not work with all backends
|
||||
|
||||
```julia
|
||||
plot(repmat(collect(1:10)',10,1); markers=[:ellipse,:rect,:diamond,:utriangle,:dtriangle,:cross,:xcross,:star1,:star2,:hexagon],labels=["ellipse","rect","diamond","utriangle","dtriangle","cross","xcross","star1","star2","hexagon"],linetype=:none,markersize=10)
|
||||
```
|
||||
|
||||

|
||||
|
||||
### Bar
|
||||
|
||||
x is the midpoint of the bar. (todo: allow passing of edges instead of midpoints)
|
||||
|
||||
```julia
|
||||
bar(randn(1000))
|
||||
```
|
||||
|
||||

|
||||
|
||||
### Histogram
|
||||
|
||||
note: fillto isn't supported on all backends
|
||||
|
||||
```julia
|
||||
histogram(randn(1000); nbins=50,fillto=20)
|
||||
```
|
||||
|
||||

|
||||
|
||||
### Subplots
|
||||
|
||||
subplot and subplot! are distinct commands which create many plots and add series to them in a circular fashion.
|
||||
You can define the layout with keyword params... either set the number of plots `n` (and optionally number of rows `nr` or
|
||||
number of columns `nc`), or you can set the layout directly with `layout`.
|
||||
|
||||
Note: Gadfly is not very friendly here, and although you can create a plot and save a PNG, I haven't been able to actually display it.
|
||||
|
||||
|
||||
```julia
|
||||
subplot(randn(100,5); layout=[1,1,3],linetypes=[:line,:hist,:dots,:step,:bar],nbins=10,legend=false)
|
||||
```
|
||||
|
||||

|
||||
|
||||
### Adding to subplots
|
||||
|
||||
Note here the automatic grid layout, as well as the order in which new series are added to the plots.
|
||||
|
||||
```julia
|
||||
subplot(randn(100,5); n=4)
|
||||
```
|
||||
|
||||

|
||||
|
||||
###
|
||||
|
||||
|
||||
|
||||
```julia
|
||||
subplot!(randn(100,3))
|
||||
```
|
||||
|
||||

|
||||
|
||||
BIN
img/immerse/immerse_example_1.png
Normal file
|
After Width: | Height: | Size: 80 KiB |
BIN
img/immerse/immerse_example_10.png
Normal file
|
After Width: | Height: | Size: 95 KiB |
BIN
img/immerse/immerse_example_11.png
Normal file
|
After Width: | Height: | Size: 22 KiB |
BIN
img/immerse/immerse_example_12.png
Normal file
|
After Width: | Height: | Size: 65 KiB |
BIN
img/immerse/immerse_example_13.png
Normal file
|
After Width: | Height: | Size: 50 KiB |
BIN
img/immerse/immerse_example_14.png
Normal file
|
After Width: | Height: | Size: 32 KiB |
BIN
img/immerse/immerse_example_15.png
Normal file
|
After Width: | Height: | Size: 17 KiB |
BIN
img/immerse/immerse_example_16.png
Normal file
|
After Width: | Height: | Size: 40 KiB |
BIN
img/immerse/immerse_example_17.png
Normal file
|
After Width: | Height: | Size: 62 KiB |
BIN
img/immerse/immerse_example_18.png
Normal file
|
After Width: | Height: | Size: 81 KiB |
BIN
img/immerse/immerse_example_2.png
Normal file
|
After Width: | Height: | Size: 31 KiB |
BIN
img/immerse/immerse_example_3.png
Normal file
|
After Width: | Height: | Size: 31 KiB |
BIN
img/immerse/immerse_example_4.png
Normal file
|
After Width: | Height: | Size: 54 KiB |
BIN
img/immerse/immerse_example_5.png
Normal file
|
After Width: | Height: | Size: 28 KiB |
BIN
img/immerse/immerse_example_6.png
Normal file
|
After Width: | Height: | Size: 32 KiB |
BIN
img/immerse/immerse_example_7.png
Normal file
|
After Width: | Height: | Size: 39 KiB |
BIN
img/immerse/immerse_example_8.png
Normal file
|
After Width: | Height: | Size: 40 KiB |
BIN
img/immerse/immerse_example_9.png
Normal file
|
After Width: | Height: | Size: 48 KiB |
@ -50,10 +50,15 @@ end
|
||||
|
||||
# -------------------------------
|
||||
|
||||
getImmerseObject(plt::Plot) = plt.o[2]
|
||||
getImmerseObject(subplt::Subplot) = buildGadflySubplotContext(subplt)
|
||||
|
||||
function savepng(::ImmersePackage, plt::PlottingObject, fn::String;
|
||||
w = 6 * Immerse.inch,
|
||||
h = 4 * Immerse.inch)
|
||||
gctx = plt.o[2]
|
||||
# gctx = plt.o[2]
|
||||
# gctx = buildGadflySubplotContext(plt)
|
||||
gctx = getImmerseObject(plt)
|
||||
Gadfly.draw(Gadfly.PNG(fn, w, h), gctx)
|
||||
nothing
|
||||
end
|
||||
@ -74,10 +79,11 @@ end
|
||||
|
||||
# create the underlying object
|
||||
function buildSubplotObject!(::ImmersePackage, subplt::Subplot)
|
||||
gctx = buildGadflySubplotContext(subplt)
|
||||
# gctx = buildGadflySubplotContext(subplt)
|
||||
|
||||
# save this for later
|
||||
subplt.o = (nothing, gctx)
|
||||
# subplt.o = (nothing, gctx)
|
||||
subplt.o = (nothing, nothing)
|
||||
end
|
||||
|
||||
|
||||
|
||||