You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

Block.java 3.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. /*
  2. * Licensed to the Apache Software Foundation (ASF) under one or more
  3. * contributor license agreements. See the NOTICE file distributed with
  4. * this work for additional information regarding copyright ownership.
  5. * The ASF licenses this file to You under the Apache License, Version 2.0
  6. * (the "License"); you may not use this file except in compliance with
  7. * the License. You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. /* $Id$ */
  18. package org.apache.fop.area;
  19. // block areas hold either more block areas or line
  20. // areas can also be used as a block spacer
  21. // a block area may have children positioned by stacking
  22. // or by relative to the parent for floats, tables and lists
  23. // cacheable object
  24. // has id information
  25. /**
  26. * This is the block area class.
  27. * It holds child block areas such as other blocks or lines.
  28. */
  29. public class Block extends BlockParent {
  30. /**
  31. * Normally stacked with other blocks.
  32. */
  33. public static final int STACK = 0;
  34. /**
  35. * Placed relative to the flow position.
  36. * This effects the flow placement of stacking normally.
  37. */
  38. public static final int RELATIVE = 1;
  39. /**
  40. * Relative to the block parent but not effecting the stacking
  41. * Used for block-container, tables and lists.
  42. */
  43. public static final int ABSOLUTE = 2;
  44. /**
  45. * Relative to a viewport/page but not effecting the stacking
  46. * Used for block-container.
  47. */
  48. public static final int FIXED = 3;
  49. private int stacking = TB;
  50. private int positioning = STACK;
  51. /** if true, allow BPD update */
  52. protected transient boolean allowBPDUpdate = true;
  53. // a block with may contain the dominant styling info in
  54. // terms of most lines or blocks with info
  55. /**
  56. * Add the block to this block area.
  57. *
  58. * @param block the block area to add
  59. */
  60. public void addBlock(Block block) {
  61. addBlock(block, true);
  62. }
  63. /**
  64. * Add the block to this block area.
  65. *
  66. * @param block the block area to add
  67. * @param autoHeight increase the height of the block.
  68. */
  69. public void addBlock(Block block, boolean autoHeight) {
  70. if (autoHeight && allowBPDUpdate && block.isStacked()) {
  71. bpd += block.getAllocBPD();
  72. }
  73. addChildArea(block);
  74. }
  75. /**
  76. * Add the line area to this block area.
  77. *
  78. * @param line the line area to add
  79. */
  80. public void addLineArea(LineArea line) {
  81. bpd += line.getAllocBPD();
  82. addChildArea(line);
  83. }
  84. /**
  85. * Set the positioning of this area.
  86. *
  87. * @param pos the positioning to use when rendering this area
  88. */
  89. public void setPositioning(int pos) {
  90. positioning = pos;
  91. }
  92. /**
  93. * Get the positioning of this area.
  94. *
  95. * @return the positioning to use when rendering this area
  96. */
  97. public int getPositioning() {
  98. return positioning;
  99. }
  100. /**
  101. * Indicates whether this block is stacked, rather than absolutely positioned.
  102. * @return true if it is stacked
  103. */
  104. public boolean isStacked() {
  105. return (getPositioning() == Block.STACK || getPositioning() == Block.RELATIVE);
  106. }
  107. /**
  108. * @return the start-indent trait
  109. */
  110. public int getStartIndent() {
  111. Integer startIndent = (Integer)getTrait(Trait.START_INDENT);
  112. return (startIndent != null ? startIndent.intValue() : 0);
  113. }
  114. }