aboutsummaryrefslogtreecommitdiffstats
path: root/docs/design/alt.design/footnotes.xml
blob: 0e2ce4bbaeb1339582791b0eb0dfed5d58d9c326 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
<?xml version="1.0" encoding="ISO-8859-1"?>
<!-- $Id$ -->
<!--
<!DOCTYPE document SYSTEM "../../xml-docs/dtd/document-v10.dtd">
-->

<document>
  <header>
    <title>Implementing footnotes</title>
    <authors>
      <person name="Peter B. West" email="pbwest@powerup.com.au"/>
    </authors>
  </header>
  <body>
    <!-- one of (anchor s1) -->
    <s1 title="Implementing footnotes in FOP">
      <p>
	Footnotes present difficulties for page layout primarily
	because their point of invocation in the flow is different
	from their point of appearance in the area tree.  All of the
	content lines of a footnote may appear on the same page as its
	invocation point, all may appear on a following page, or the
	lines may be split over a page or pages.  (This characteristic
	leads to another problem when a footnote overflows the last
	page of flow content, but that difficulty will not be
	discussed here.)  This note considers some aspects of the
	implementation of footnotes in a galley-based design.
      </p>
      <s2 title="Footnotes and galleys">
	<p>
	  In the structure described in the <link href=
	  "../galleys.html" >introduction to FOP galleys</link>,
	  footnotes would be pre-processed as galleys themselves, but
	  they would remain attached as subtrees to their points of
	  invocation in the main text.  Allocation to a
	  footnote-reference-area would only occur in the resolution
	  to Area nodes.
	</p>
	<p>
	  When footnotes are introduced, the communication between
	  galleys and layout manager, as mentioned <link href=
	  "../galleys.html#pre-processing" >above</link>, would be
	  affected.  The returned information would two b-p-d values:
	  the primary line-area b-p-d impact and the footnote b-p-d
	  impact.  The distinction is necessary for two reasons; to
	  alert the layout manager to the first footnote of the page,
	  and because the footnote b-p-d will always impact the
	  main-reference-area b-p-d, whereas the primary inline-area
	  may not, e.g. in the case of multiple span-areas.
	</p>
      </s2>
      <s2 title="Multiple columns and footnotes">
	<note>
	  A possible method for multi-column layout and balancing
	  with footnotes, using a galley-based approach.
	</note>
	<p>
	  This note assumes a galley, as discussed <link href=
	  "../galleys.html" >elsewhere</link>, flowing text with
	  footnotes and possibly other blocks into a possibly
	  multi-column area.  The logic of flowing into multiple
	  columns is trivially applied to a single column.  The galley
	  is manipulated within the context of the <em>layout
	  tree</em>.
	</p>
	<p>
	  Associated with the galley are two sets of data.
	  One contains the maps of all "natural" break-points and
	  the of all hyphenation break-points.  This set is
	  constructed at the time of construction of the galley and
	  is a constant for a given galley.  The second contains
	  dynamic data which represents one possible attempt to lay
	  out the galley.  There may be multiple sets of such data
	  to reflect varying attempts.  The data of this set are,
	  essentially, representations of line-areas, with the supporting
	  information necessary to determine these line-areas.
	</p>
	<p>
	  The line-area data includes the boundaries within the
	  galley of each line-area, the boundaries of each column
	  and the boundaries of the "page", or main area.  When a
	  line-area boundary occurs at a hyphenation point, a
	  "virtual hyphen" is assumed and accounted for in the
	  i-p-d.  As mentioned, individual footnote galleys will
	  hang from the parent galley.  The associated data of the
	  footnote galleys is similar: a once-only break-points map,
	  and one or more line-area maps.  No column boundaries are
	  required, but a page boundary is required at the end of
	  the last footnote or where a footnote breaks across a page
	  boundary.
	</p>
	<p>
	  A number of b-p-d values are also maintained.  For each
	  line-area, the b-p-d, the main area b-p-d increment, the
	  footnote b-p-d increment and the footnote's page-related
	  b-p-d increment are required.  The main-area b-p-d
	  increments for any particular line-area are dependent on
	  the column position of the line-area.  Total b-p-d's are
	  also kept: total footnote b-p-d, total main area b-p-d,
	  and totals for each column.<br/><br/>
	  <strong>Figure 1</strong> Columns before first footnote.
	</p>
	<figure src="initial-column-values.png" alt="Columns before
		first footnote"/>
      </s2>
      <s2 title="Balancing columns">
	<p>
	  <strong>Figure 2</strong> Adding a line area with first
	  footnote.
	</p>
	<figure src="line-area-5.png"
		alt="Columns after adding first footnote"/>
	<p>
	  Columns are balanced dynamically in the galley preliminary
	  layout.  While the galley retains its basic linear
	  structure, the accompanying data structures accomplish
	  column distribution and balancing.  As each line-area is
	  added, the columns are re-balanced.  <strong>N.B.</strong>
	  This re-balancing involves only some of the dynamic data
	  associated with the participating galley(s).  The data
	  structures associating breakpoints with the beginning and
	  end of individual line areas does not change in
	  re-balancing; only the association of line-area with column,
	  and, possibly, the various impact values for each line-area.
	  <br/><br/>
	  <strong>Figure 3</strong> Adding a line area with next
	  footnote.
	</p>
	<figure src="line-area-6.png"
		alt="Columns after adding next footnote"/>
      </s2>
      <s2 title="Layout managers in the flow of control">
	<note>To be developed.</note>
      </s2>
    </s1>
  </body>
</document>