Skip to content

Releases: nteract/semiotic

Canvas Rendering Improvements, Custom Networks

02 Jan 22:39
Compare
Choose a tag to compare

Features

  • You can pass custom d3-forceSimulation simulations to NetworkFrame, as a simulation parameter in the networkType. It's demonstrated here to create bubble charts and multi-foci charts.
  • All frames have a baseMarkProps that can take an object with props to apply to all marks generated by the frame. This is primarily to leverage the new feature in semiotic-mark that lets you defined transitionDuration. For now it only takes an object, so you can across the board set transitions to be something other than the 1000ms default that Semiotic has been using up to this point. You can try it out in your frame by adding something like:
   baseMarkProps={{ transitionDuration: 2000 }}

To set all transitions to 2 seconds or something more nuanced like:

   baseMarkProps={{ transitionDuration: { default: 500, fill: 2500 }}}

To make fill transitions take 2.5 seconds and all other transitions take 0.5 seconds.

  • canvasPieces & canvasConnectors are now honored in <ORFrame> and will render those elements to canvas. canvasSummaries is still not available.
  • canvasPostProcess is available on all frames. It is fired after canvas rendering and is passed (canvas, context, size) so you can graphically modify your chart. For instance if you want it to have a glowy look like this:
    screen shot 2018-01-02 at 1 24 15 pm
    You can add the following code to the Frame:
   canvasPostProcess={(canvas, context, size) => {
  const dataURL = canvas.toDataURL("image/png")
  const baseImage = document.createElement("img")

  baseImage.src = dataURL
  baseImage.onload = () => {
    context.clearRect(0, 0, size[0] + 120, size[1] + 120)
    context.filter = "blur(10px)"
    context.drawImage(baseImage, 0, 0)
    context.filter = "blur(5px)"
    context.drawImage(baseImage, 0, 0)
    context.filter = "none"
    context.drawImage(baseImage, 0, 0)
  }}

It also will do a fun Chuck Close style pixelation if you pass canvasPostProcess={"chuckClose"}

Changes

  • This uses semiotic-mark@0.1.0 which no longer uses flubber. Instead, complex shapes that won't transition well don't use transitions. Flubber was too big and still caused distracting changes in shapes when doing the interpolation--it's great for abstract shapes but not so great for the lines and areas in a traditional chart.
  • Default for <XYFrame>'s lineIDAccessor is now d => d.semioticLineID instead of d => d.id because the latter would conflict with the occasional dataset.

summaryType Bug Fixes

16 Dec 03:13
Compare
Choose a tag to compare

Fixes a major bug where horizontal summaryType was reversed and a little bug where Joy Plots weren't quite aligned.

Improved customMark for ORFrame "timeline" type

16 Dec 03:14
Compare
Choose a tag to compare

"timeline" type in ORFrame sends better settings to the customMark generator

Sankeys with Cycles

11 Dec 19:00
Compare
Choose a tag to compare

Features

  • Sankeys in NetworkFrame now accept networks with cycles and render them using Tom Shanley's d3-sankey-circular layout.
    screen shot 2017-12-11 at 10 55 21 am
  • Add a relative tag to bucketized summaryTypes in ORFrame to allow the visualization to display the relative size of the data (with the max being the max value for that category) as opposed to the default behavior which sizes graphical elements by the max value across all categories.

Fixes

  • Margin has been fixed so that passing a numerical value is properly treated as margin for all sides.

Multisubject Annotations & Custom Point Marks

04 Dec 20:49
Compare
Choose a tag to compare

Features:

  • All axes will automatically draw a <line> element with class axis-baseline along the baseline of the axis. You can restyle or hide it with CSS.
  • react-annotation annotations in XYFrame and ORFrame will honor a coordinates array and draw multi-subject annotations when you send datapoints in that array.
  • customPointMark in XYFrame can now return any JSX SVG instead of just a semiotic-mark <Mark> element. It also passes { d, i, xScale, yScale } so you can draw marks whose shape depends on data values in chartspace.

Fixes:

  • motifs mode in NetworkFrame is working again. Singletons are now sorted into a single component.

You can see most of this in action in the Comet Plots example.

screen shot 2017-12-04 at 12 49 07 pm

Timelines and TickLines

29 Nov 19:00
Compare
Choose a tag to compare

in ORFrame

  • pixelColumnWidth in ORFrame now allows you to specify the size of a column as a number and will result in a frame with a size based on the number of columns times the specified size

  • timeline is a new type that requires an rAccessor that returns a two-piece array that designates start and end of timeline/Gantt chart-style bands of data.

screen shot 2017-11-29 at 10 37 10 am

in Axis

  • ticklineGenerator allows you to specify a function which will be passed ({ xy, orient }) which you can return SVG JSX to draw your own custom ticks
  • tickSize allows you to specify the pixel length/height of the tick generated by the axis. Use negative values to draw away from the chart. Use multiple axes on the same orient if you want to draw and overlap different axes or use ticklineGenerator to draw a more custom tick

screen shot 2017-11-29 at 10 37 35 am

screen shot 2017-11-29 at 10 37 50 am

Fixes, static version, more examples

21 Nov 02:22
Compare
Choose a tag to compare

FIXES

  • Whole pie piece pie charts will not honor oPadding and slices will not end up with negative size if reduced by oPadding.
  • Annotation handling updates other properties even if it's not required for the annotations to change, also support a dataVersion flag in bump type annotation layouts so you can tell it to re-fire the layout
  • Curly arc brackets were incorrectly calculating the largeArcFlag resulting in cool but terrible arcs

FEATURES

  • unpkg support from @tmcw!
  • Honor new extents in brushes to allow programmatic brush extents (feature shown in the Swarm Brush, Line Brush and Minimap examples)

NEW EXAMPLES
Show how to use the MinimapXYFrame as an isolated example
minimap
https://emeeks.github.io/semiotic/#/semiotic/minimap

Fun with backgroundGraphics
untitled
https://emeeks.github.io/semiotic/#/datasketches

Little Fixes

18 Nov 05:04
Compare
Choose a tag to compare

This update resolves a few problems most people wouldn't have run into unless they were using the advanced annotation features, like when your annotation attributes change but your annotation layout doesn't say they need to be repositioned.

It also adds a more accessible new example for a custom type in ORFrame:
https://emeeks.github.io/semiotic/#/semiotic/custommark

screen shot 2017-11-17 at 8 59 58 pm

v1.2.3

18 Nov 05:05
Compare
Choose a tag to compare

Updates the version of react-annotation to restore passing custom events to annotations (you'll still need to enable pointer-events on them via CSS though). And awesome curly arc brackets.

Bracket Annotations

13 Nov 03:40
Compare
Choose a tag to compare

feat: "categories" annotation for ORFrame that displays bracket annotations for categories in a friendly way, see the Violin Chart in the docs.
feat: Expose better drawing instructions for clusterbar type in ORFrame
fix: fix radial ordering bug for middle-ordered types (violin, point, swarm)

screen shot 2017-11-12 at 7 32 00 pm

screen shot 2017-11-12 at 7 32 18 pm