Home · All Classes · Main Classes · Grouped Classes · Modules · Functions

[Previous: QtSvg Module] [Qt's Modules] [Next: QtXml Module]

QtWebKit Module

An introduction to the QtWebKit module. More...

Classes

QWebFrameRepresents a frame in a web page
QWebHistoryRepresents the history of a QWebPage
QWebHistoryInterfaceInterface to implement link history
QWebHistoryItemRepresents one item in the history of a QWebPage
QWebPageWidget that is used to view and edit web documents
QWebSettingsObjects that is used to store the settings used by QWebPage and QWebFrame
QWebViewWidget that is used to view and edit web documents

Detailed Description

QtWebKit provides a Web browser engine that makes it easy to embed content from the World Wide Web into your Qt application. At the same time Web content can be enhanced with native controls.

QtWebKit provides facilities for rendering of HyperText Markup Language (HTML), Extensible HyperText Markup Language (XHTML) and Scalable Vector Graphics (SVG) documents, styled using Cascading Style Sheets (CSS) and scripted with JavaScript.

A bridge between the JavaScript execution environment and the Qt object model makes it possible for custom QObjects to be scripted. Integration with the Qt networking module enables Web pages to be transparently loaded from Web servers, the local file system or even the Qt resource system.

In addition to providing pure rendering features, HTML documents can be made fully editable to the user through the use of the contenteditable attribute on HTML elements.

QtWebKit is based on the Open Source WebKit engine. More information about WebKit itself can be found on the WebKit Open Source Project Web site.

The QtWebKit module is part of the Qt Desktop Edition, and the Qt Open Source Edition.

Topics:

Configuring the Build Process

Applications that use QtWebKit's classes need to be configured to be built against the QtWebKit module. The following declaration in a qmake project file ensures that an application is compiled and linked appropriately:

     QT += webkit

This line is necessary because only the QtCore and QtGui modules are used in the default build process.

To include the definitions of the module's classes, use the following directive:

     #include <QtWebKit>

Architecture

The easiest way to render content is through the QWebView class. As a widget it can be embedded into your forms or a graphics view, and it provides convenience functions for downloading and rendering web sites.

     QWebView *view = new QWebView(parent);
     view->load(QUrl("http://www.trolltech.com/"));
     view->show();

QWebView acts as a view onto Web pages, each of which is represented by an instance of the QWebPage class. QWebPage provides access to the document structure in a page, describing features such as frames, the navigation history, and the undo/redo stack for editable content.

HTML documents can be nested using frames in a frameset. An individual frame in HTML is represented using the QWebFrame class. It includes the bridge to the JavaScript window object and can be painted using QPainter. Each QWebPage has one QWebFrame object as its main frame.

Individual browser features, defaults and other settings can be configured through the QWebSettings class. It is possible to provide defaults for all QWebPage instances through the default settings. Individual attributes can be overidden by the page specific settings object.

License Information

Copyright (C) 2007-2008 Trolltech ASA

Copyright (C) 2007 Staikos Computing Services Inc.

This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.

This library 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 Library General Public License for more details.

You should have received a copy of the GNU Library General Public License along with this library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.

[Previous: QtSvg Module] [Qt's Modules] [Next: QtXml Module]


Copyright © 2008 Trolltech Trademarks
Qt 4.4.0-beta1