2003-06-30 16:44:03 +04:00
|
|
|
/*
|
|
|
|
* Copyright 2003 James Bursa <bursa@users.sourceforge.net>
|
2007-08-08 20:16:03 +04:00
|
|
|
*
|
|
|
|
* This file is part of NetSurf, http://www.netsurf-browser.org/
|
|
|
|
*
|
|
|
|
* NetSurf is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; version 2 of the License.
|
|
|
|
*
|
|
|
|
* NetSurf is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2002-05-04 23:57:18 +04:00
|
|
|
*/
|
|
|
|
|
2016-04-24 01:32:21 +03:00
|
|
|
/**
|
|
|
|
* \file
|
2004-02-11 20:15:36 +03:00
|
|
|
* HTML layout (interface).
|
|
|
|
*
|
|
|
|
* The main interface to the layout code is layout_document(), which takes a
|
|
|
|
* normalized box tree and assigns coordinates and dimensions to the boxes, and
|
|
|
|
* also adds boxes to the tree (eg. when formatting lines of text).
|
|
|
|
*/
|
|
|
|
|
2002-08-12 03:04:02 +04:00
|
|
|
#ifndef _NETSURF_RENDER_LAYOUT_H_
|
|
|
|
#define _NETSURF_RENDER_LAYOUT_H_
|
|
|
|
|
2004-10-23 00:58:11 +04:00
|
|
|
struct box;
|
2011-05-07 00:40:09 +04:00
|
|
|
struct html_content;
|
2016-04-24 01:32:21 +03:00
|
|
|
struct gui_layout_table;
|
2004-10-23 00:58:11 +04:00
|
|
|
|
2016-04-24 01:32:21 +03:00
|
|
|
/**
|
|
|
|
* Calculate positions of boxes in a document.
|
|
|
|
*
|
|
|
|
* \param content content of type CONTENT_HTML
|
|
|
|
* \param width available width
|
|
|
|
* \param height available height
|
|
|
|
* \return true on success, false on memory exhaustion
|
|
|
|
*/
|
2011-05-07 00:40:09 +04:00
|
|
|
bool layout_document(struct html_content *content, int width, int height);
|
2016-04-24 01:32:21 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Layout lines of text or inline boxes with floats.
|
|
|
|
*
|
2016-09-13 11:16:31 +03:00
|
|
|
* \param box inline container box
|
2016-04-24 01:32:21 +03:00
|
|
|
* \param width horizontal space available
|
|
|
|
* \param cont ancestor box which defines horizontal space, for floats
|
|
|
|
* \param cx box position relative to cont
|
|
|
|
* \param cy box position relative to cont
|
|
|
|
* \param content memory pool for any new boxes
|
|
|
|
* \return true on success, false on memory exhaustion
|
|
|
|
*/
|
|
|
|
bool layout_inline_container(struct box *box, int width, struct box *cont, int cx, int cy, struct html_content *content);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Recursively calculate the descendant_[xy][01] values for a laid-out box tree
|
|
|
|
* and inform iframe browser windows of their size and position.
|
|
|
|
*
|
|
|
|
* \param box tree of boxes to update
|
|
|
|
*/
|
2004-10-23 00:58:11 +04:00
|
|
|
void layout_calculate_descendant_bboxes(struct box *box);
|
2016-04-24 01:32:21 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Calculate minimum and maximum width of a table.
|
|
|
|
*
|
|
|
|
* \param table box of type TABLE
|
|
|
|
* \param font_func Font functions
|
|
|
|
* \post table->min_width and table->max_width filled in,
|
|
|
|
* 0 <= table->min_width <= table->max_width
|
|
|
|
*/
|
|
|
|
void layout_minmax_table(struct box *table, const struct gui_layout_table *font_func);
|
|
|
|
|
2002-08-12 03:04:02 +04:00
|
|
|
#endif
|