Note
Go to the end to download the full example code.
Scatter Plot Color Slicing#
Example showing color slice for scatter plot.

/home/runner/work/fastplotlib/fastplotlib/fastplotlib/graphics/features/_base.py:18: UserWarning: casting float64 array to float32
warn(f"casting {array.dtype} array to float32")
# test_example = false
import fastplotlib as fpl
import numpy as np
figure = fpl.Figure(size=(700, 560))
# create a random distribution of 10,000 xyz coordinates
n_points = 5_000
# dimensions always have to be [n_points, xyz]
dims = (n_points, 3)
clouds_offset = 30
# create some random clouds
normal = np.random.normal(size=dims, scale=5)
# stack the data into a single array
cloud = np.vstack(
[
normal - clouds_offset,
normal,
normal + clouds_offset,
]
)
# color each of them separately
colors = ["yellow"] * n_points + ["cyan"] * n_points + ["magenta"] * n_points
# use an alpha value since this will be a lot of points
figure[0, 0].add_scatter(
data=cloud, sizes=3, colors=colors, alpha_mode="weighted_blend", alpha=0.6
)
figure.show()
scatter = figure[0, 0].graphics[0]
scatter.colors[0:75] = "red"
scatter.colors[75:150] = "white"
scatter.colors[::2] = "blue"
# NOTE: fpl.loop.run() should not be used for interactive sessions
# See the "JupyterLab and IPython" section in the user guide
if __name__ == "__main__":
print(__doc__)
fpl.loop.run()
Total running time of the script: (0 minutes 0.483 seconds)