Package org.pentaho.reporting.engine.classic.core.layout.process.layoutrules

Examples of org.pentaho.reporting.engine.classic.core.layout.process.layoutrules.InlineSequenceElement


    long length = sequenceList.getMinimumLength(startPosition);
    boolean lastNodeWasSpacer = (lastType == InlineSequenceElement.Classification.CONTENT &&
          sequenceList.getNode(startPosition).getNodeType() == LayoutNodeTypes.TYPE_NODE_SPACER);
    for (int i = startPosition + 1; i < sequenceList.size(); i += 1)
    {
      final InlineSequenceElement sequenceElement = sequenceList.getSequenceElement(i);
      final InlineSequenceElement.Classification classification = sequenceElement.getType();
      if (lastNodeWasSpacer == false &&
          lastType != InlineSequenceElement.Classification.START &&
          classification != InlineSequenceElement.Classification.END)
      {
        final int chunkStart = startPosition;
View Full Code Here


    boolean first = stripFirstSpacer;
    long length = 0;
    for (int i = chunk.getStart(); i < chunkEnd; i++)
    {
      final RenderNode node = chunk.getNode(i);
      final InlineSequenceElement sequenceElement = chunk.getSequenceElement(i);
      final InlineSequenceElement.Classification classification = sequenceElement.getType();
      if (classification == InlineSequenceElement.Classification.CONTENT)
      {
        if (first && node.getNodeType() == LayoutNodeTypes.TYPE_NODE_SPACER)
        {
          continue;
        }
        first = false;
      }
      final long minimumLength = sequenceElement.getMaximumWidth(node);
      length  += minimumLength;
    }
    return length;
  }
View Full Code Here

        // simple, add that chunk ..
        final int chunkEnd = chunk.getEnd();
        for (int i = chunk.getStart(); i < chunkEnd; i++)
        {
          final RenderNode node = chunk.getNode(i);
          final InlineSequenceElement sequenceElement = chunk.getSequenceElement(i);
          final InlineSequenceElement.Classification classification = sequenceElement.getType();
          final long minimumLength = sequenceElement.getMaximumWidth(node);

          if (classification == InlineSequenceElement.Classification.START)
          {
            node.setCachedX(posX);
            final RenderBox renderBox = (RenderBox) node.derive(false);
View Full Code Here

    int startIndex = 0;
    boolean lastNodeWasSpacer = (lastElementType == InlineSequenceElement.CONTENT &&
        nodes[0].getNodeType() == LayoutNodeTypes.TYPE_NODE_SPACER);
    for (int i = 1; i < maxPos; i++)
    {
      final InlineSequenceElement element = elements[i];
      final int elementType = element.getClassification();
      if (lastNodeWasSpacer == false &&
          lastElementType != InlineSequenceElement.START &&
          elementType != InlineSequenceElement.END)
      {
        final int newIndex = handleElement(startIndex, i - startIndex);
View Full Code Here

    RenderBox firstBox = null;
    RenderBox box = null;
    for (int i = 0; i < lastPosition; i++)
    {
      final RenderNode node = nodes[i];
      final InlineSequenceElement element = sequenceElements[i];
      if (element instanceof EndSequenceElement)
      {
        contexts.pop();
        final long boxX2 = (elementPositions[i] + elementDimensions[i]);
        box.setCachedWidth(boxX2 - box.getCachedX());
View Full Code Here

    boolean changed = false;
    int targetIndex = 0;
    for (int i = 0; i < this.sequenceFill; i += 1)
    {
      final InlineSequenceElement ise = this.sequenceElements[i];
      final InlineSequenceElement.Classification type = ise.getType();
      if (type == InlineSequenceElement.Classification.CONTENT)
      {
        final RenderNode node = this.nodes[i];
        if (node instanceof SpacerRenderNode)
        {
View Full Code Here

      // First, the simple case: The line's content did fully fit into the linebox. No linebreaks were necessary.
      RenderBox firstBox = null;
      for (int i = 0; i < lastPosition; i++)
      {
        final RenderNode node = nodes[i];
        final InlineSequenceElement element = sequenceElements[i];
        if (element instanceof EndSequenceElement)
        {
          final long boxX2 = (elementPositions[i] + elementDimensions[i]);
          final RenderBox box = (RenderBox) node;
          box.setCachedWidth(boxX2 - box.getCachedX());
View Full Code Here

  {
    long spacerCount = 0;
    for (int i = 0; i < index; i++)
    {
      // justify text
      final InlineSequenceElement ise = sequenceElements[i];
      final RenderNode node = nodes[i];
      if (node.getNodeType() == LayoutNodeTypes.TYPE_NODE_SPACER)
      {
        spacerCount += ise.getMaximumWidth(node);
      }
    }

    if (spacerCount > 0)
    {
      final double extraSpacePerSpacerUnit = extraSpace / (double) spacerCount;
      long shift = 0;
      for (int i = 0; i < index; i++)
      {
        elementPositions[i] += shift;

        // justify text
        final InlineSequenceElement ise = sequenceElements[i];
        final RenderNode node = nodes[i];
        if (node.getNodeType() == LayoutNodeTypes.TYPE_NODE_SPACER)
        {
          final long width = ise.getMaximumWidth(node);
          final long extraSpaceHere = (long) (extraSpacePerSpacerUnit * width);
          elementDimensions[i] += extraSpaceHere;
          shift += extraSpaceHere;
        }
      }
View Full Code Here

    long width = 0;
    final int endIndex = start + count;

    // In the given range, there should be only one content element.
    InlineSequenceElement contentElement = null;
    int contentIndex = start;
    for (int i = start; i < endIndex; i++)
    {
      final InlineSequenceElement element = sequenceElements[i];
      final RenderNode node = nodes[i];
      if (element instanceof StartSequenceElement ||
          element instanceof EndSequenceElement)
      {
        width += element.getMaximumWidth(node);
        continue;
      }

      width += element.getMaximumWidth(node);
      contentElement = element;
      contentIndex = i;
    }

    final long nextPosition = getPosition() + width;
    final long lastPageBreak = getPageBreak(getPagebreakCount() - 1);
    // Do we cross a page boundary?
    if (nextPosition > lastPageBreak)
    {
      // On outer break: Stop processing

      // Dont write through to the stored position; but prepare if
      // we have to fallback ..
      long position = getPosition();
      for (int i = start; i < endIndex; i++)
      {
        final InlineSequenceElement element = sequenceElements[i];
        final RenderNode node = nodes[i];
        elementPositions[i] = position;
        final long elementWidth = element.getMaximumWidth(node);
        elementDimensions[i] = elementWidth;
        position += elementWidth;
      }

      // we cross a pagebreak. Stop working on it - we bail out here.

      if (contentElement instanceof TextSequenceElement)
      {
        // the element may be splittable. Test, and if so, give a hint to the
        // outside world ..
        setSkipIndex(endIndex);
        setBreakableIndex(contentIndex);
        return (start);
      }

      // This is the first element and it still does not fit. How evil.
      if (start == 0)
      {
        if (contentElement instanceof InlineBoxSequenceElement)
        {
          final RenderNode node = nodes[contentIndex];
          if ((node.getNodeType() & LayoutNodeTypes.MASK_BOX) == LayoutNodeTypes.MASK_BOX)
          {
            // OK, limit the size of the box to the maximum line width and
            // revalidate it.
            final long contentPosition = elementPositions[contentIndex];
            final RenderBox box = (RenderBox) node;
            final long maxWidth = (getEndOfLine() - contentPosition);
            computeInlineBlock(box, contentPosition, maxWidth);

            elementDimensions[endIndex - 1] = node.getCachedWidth();
          }
        }
        setSkipIndex(endIndex);
      }
      return (start);
    }

    final long innerPagebreak = getPageBreak(getPageSegment());
    if (nextPosition > innerPagebreak)
    {
      // It is an inner pagebreak and the current element would not fit into the remaining space.
      // Move the element to the next page segment (but only if the start is not on
      setPosition(innerPagebreak);
      setPageSegment(getPageSegment() + 1);
    }


    // No, it is an ordinary advance ..
    // Check, whether we hit an item-sequence element
    if (contentElement instanceof InlineBoxSequenceElement == false)
    {
      for (int i = start; i < endIndex; i++)
      {
        final RenderNode node = nodes[i];
        final InlineSequenceElement element = sequenceElements[i];
        elementPositions[i] = getPosition();
        final long elementWidth = element.getMaximumWidth(node);
        elementDimensions[i] = elementWidth;
        addPosition(elementWidth);
      }
      return endIndex;
    }

    // Handle the ItemSequence element.

    // This is a bit more complicated. So we encountered an inline-block
    // element here. That means, the element will try to occuppy its
    // maximum-content-width.
//    Log.debug("Advance block at index " + contentIndex);
//    final long ceWidth = contentElement.getMinimumWidth();
//    final long extraSpace = contentElement.getMaximumWidth();
//    Log.debug("Advance block: Min " + ceWidth);
//    Log.debug("Advance block: Max " + extraSpace);

    final RenderNode contentNode = nodes[contentIndex];
    final long itemElementWidth = contentElement.getMaximumWidth(contentNode);

    if ((contentNode.getNodeType() & LayoutNodeTypes.MASK_BOX) == LayoutNodeTypes.MASK_BOX)
    {
      final RenderBox box = (RenderBox) contentNode;
      computeInlineBlock(box, getPosition(), itemElementWidth);
    }
    else
    {
      contentNode.setCachedX(getPosition());
      contentNode.setCachedWidth(itemElementWidth);
    }

    final long preferredEndingPos = getPosition() + itemElementWidth;
    if (preferredEndingPos > getEndOfLine())
    {
      // We would eat the whole space up to the end of the line and more
      // So lets move that element to the next line instead...

      // But: We could easily end in an endless loop here. So check whether
      // the element is the first in the line
      if (start == 0)
      {
        // As it is guaranteed, that each chunk contains at least one item,
        // checking for start == 0 is safe enough ..
        return endIndex;
      }

      return start;
    }

    for (int i = start; i < contentIndex; i++)
    {
      final InlineSequenceElement element = sequenceElements[i];
      final RenderNode node = nodes[contentIndex];
      final long elementWidth = element.getMaximumWidth(node);
      elementPositions[i] = getPosition();
      elementDimensions[i] = elementWidth;
      addPosition(elementWidth);
    }

    elementPositions[contentIndex] = getPosition();
    elementDimensions[contentIndex] = itemElementWidth;
    setPosition(preferredEndingPos);

    for (int i = contentIndex + 1; i < endIndex; i++)
    {
      final InlineSequenceElement element = sequenceElements[i];
      final RenderNode node = nodes[contentIndex];
      final long elementWidth = element.getMaximumWidth(node);
      elementPositions[i] = getPosition();
      elementDimensions[i] = elementWidth;
      addPosition(elementWidth);
    }
View Full Code Here

TOP

Related Classes of org.pentaho.reporting.engine.classic.core.layout.process.layoutrules.InlineSequenceElement

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.