Ejemplo n.º 1
0
  @Override
  public void drawExpression(
      AdvancedContext2d ctx,
      OverlayContext overlay,
      DiagramObject item,
      int t,
      double min,
      double max,
      Double factor,
      Coordinate offset) {
    GraphComplex complex = item.getGraphObject();
    double percentage =
        complex.getHitParticipants().size() / (double) complex.getParticipants().size();

    Node node = (Node) item;
    NodeProperties prop = NodePropertiesFactory.transform(node.getProp(), factor, offset);

    ctx.save();
    setColourProperties(ctx, ColourProfileType.ANALYSIS);
    if (item.getIsDisease() != null)
      ctx.setStrokeStyle(DiagramColours.get().PROFILE.getProperties().getDisease());
    shape(ctx, prop, node.getNeedDashedBorder());
    ctx.fill();
    ctx.stroke();
    ctx.restore();

    List<Double> expression = new LinkedList<>(complex.getParticipantsExpression(t).values());
    Collections.sort(expression); // Collections.sort(expression, Collections.reverseOrder());
    Double value = ExpressionUtil.median(expression);

    AdvancedContext2d buffer = overlay.getBuffer();

    buffer.save();
    buffer.setFillStyle(AnalysisColours.get().expressionGradient.getColor(value, min, max));
    buffer.octagon(
        prop.getX(),
        prop.getY(),
        prop.getWidth(),
        prop.getHeight(),
        RendererProperties.COMPLEX_RECT_ARC_WIDTH);
    buffer.fill();
    buffer.setGlobalCompositeOperation(Context2d.Composite.SOURCE_IN);
    buffer.fillRect(prop.getX(), prop.getY(), prop.getWidth() * percentage, prop.getHeight());

    overlay
        .getOverlay()
        .drawImage(buffer.getCanvas(), 0, 0); // TODO: Improve this to copy only the region
    buffer.restore();
  }
Ejemplo n.º 2
0
  @Override
  public Double getExpressionHovered(DiagramObject item, Coordinate pos, int t) {
    GraphComplex complex = item.getGraphObject();
    NodeProperties prop = ((Node) item).getProp();

    List<Double> expression = new LinkedList<>(complex.getParticipantsExpression(t).values());
    if (expression.isEmpty()) return null;

    Collections.sort(expression); // Collections.sort(expression, Collections.reverseOrder());
    double value = ExpressionUtil.median(expression);
    double percentage =
        complex.getHitParticipants().size() / (double) complex.getParticipants().size();

    double minX = prop.getX();
    double maxX = minX + prop.getWidth() * percentage;
    if (pos.getX() > minX && pos.getX() <= maxX) return value;
    return null;
  }