Viadeo Twitter Google Bookmarks ! Facebook Digg del.icio.us MySpace Yahoo MyWeb Blinklist Netvouz Reddit Simpy StumbleUpon Bookmarks Windows Live Favorites 
Logo Documentation Qt ·  Page d'accueil  ·  Toutes les classes  ·  Toutes les fonctions  ·  Vues d'ensemble  · 

QtWebKit Module

An introduction to the QtWebKit module. More...

Classes

QWebDatabaseAccess to HTML 5 databases created with JavaScript
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
QWebHitTestResultInformation about the web page content after a hit test
QWebPageObject to view and edit web documents
QWebPluginFactoryCreates plugins to be embedded into web pages
QWebSecurityOriginDefines a security boundary for web sites
QWebSettingsObject 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 Full Framework Edition, and the Open Source Versions of Qt.

Note: Building the QtWebKit module with debugging symbols is problematic on many platforms due to the size of the WebKit engine. We recommend building the module in release mode only for embedded platforms.

Note: Web site icons, also known as "FavIcons", are currently not supported on Windows. We plan to address this in a future release.

Note: WebKit has certain minimum requirements that must be met on Embedded Linux systems. See the Qt for Embedded Linux Requirements document for more information.

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://qt.nokia.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.

Netscape Plugin Support

Note: Netscape plugin support is only available on desktop platforms.

Since WebKit supports the Netscape Plugin API, Qt applications can display Web pages that embed common plugins on platforms for which those plugins are available. To enable plugin support, the user must have the appropriate binary files for those plugins installed and the QWebSettings::PluginsEnabled attribute must be enabled for the application.

The following locations are searched for plugins:

Linux/Unix (X11)Windows
  • .mozilla/plugins in the user's home directory
  • .netscape/plugins in the user's home directory
  • System locations, such as
    • /usr/lib/browser/plugins
    • /usr/local/lib/mozilla/plugins
    • /usr/lib/firefox/plugins
    • /usr/lib64/browser-plugins
    • /usr/lib/browser-plugins
    • /usr/lib/mozilla/plugins
    • /usr/local/netscape/plugins
    • /opt/mozilla/plugins
    • /opt/mozilla/lib/plugins
    • /opt/netscape/plugins
    • /opt/netscape/communicator/plugins
    • /usr/lib/netscape/plugins
    • /usr/lib/netscape/plugins-libc5
    • /usr/lib/netscape/plugins-libc6
    • /usr/lib64/netscape/plugins
    • /usr/lib64/mozilla/plugins
  • Locations specified by environment variables:
    • $MOZILLA_HOME/plugins
    • $MOZ_PLUGIN_PATH
    • $QTWEBKIT_PLUGIN_PATH
  • The user's Application Data\Mozilla\plugins directory
  • Standard system locations of plugins for Quicktime, Flash, etc.
Mac OS X
  • Library/Internet Plug-Ins in the user's home directory
  • The system /Library/Internet Plug-Ins directory

License Information

This is a snapshot of the Qt port of WebKit. The exact version information can be found in the src/3rdparty/webkit/VERSION file supplied with Qt.

Qt Commercial Edition licensees that wish to distribute applications that use the QtWebKit module need to be aware of their obligations under the GNU Lesser General Public License (LGPL).

Developers using the Open Source Edition can choose to redistribute the module under the appropriate version of the GNU LGPL; version 2.1 for applications and libraries licensed under the GNU GPL version 2, or version 3 for applications and libraries licensed under the GNU GPL version 2.

WebKit is licensed under the GNU Library General Public License. Individual contributor names and copyright dates can be found inline in the code.

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]

Publicité

Best Of

Actualités les plus lues

Semaine
Mois
Année
  1. « Quelque chose ne va vraiment pas avec les développeurs "modernes" », un développeur à "l'ancienne" critique la multiplication des bibliothèques 64
  2. Apercevoir la troisième dimension ou l'utilisation multithreadée d'OpenGL dans Qt, un article des Qt Quarterly traduit par Guillaume Belz 0
  3. Les développeurs ignorent-ils trop les failles découvertes dans leur code ? Prenez-vous en compte les remarques des autres ? 17
  4. BlackBerry 10 : premières images du prochain OS de RIM qui devrait intégrer des widgets et des tuiles inspirées de Windows Phone 0
  5. Quelles nouveautés de C++11 Visual C++ doit-il rapidement intégrer ? Donnez-nous votre avis 10
  6. Adieu qmake, bienvenue qbs : Qt Building Suite, un outil déclaratif et extensible pour la compilation de projets Qt 17
  7. La rubrique Qt a besoin de vous ! 1
Page suivante

Le blog Digia au hasard

Logo

Créer des applications avec un style Metro avec Qt, exemples en QML et C++, un article de Digia Qt traduit par Thibaut Cuvelier

Le blog Digia est l'endroit privilégié pour la communication sur l'édition commerciale de Qt, où des réponses publiques sont apportées aux questions les plus posées au support. Lire l'article.

Communauté

Ressources

Liens utiles

Contact

  • Vous souhaitez rejoindre la rédaction ou proposer un tutoriel, une traduction, une question... ? Postez dans le forum Contribuez ou contactez-nous par MP ou par email (voir en bas de page).

Qt dans le magazine

Cette page est une traduction d'une page de la documentation de Qt, écrite par Nokia Corporation and/or its subsidiary(-ies). Les éventuels problèmes résultant d'une mauvaise traduction ne sont pas imputables à Nokia. Qt 4.5
Copyright © 2012 Developpez LLC. Tous droits réservés Developpez LLC. Aucune reproduction, même partielle, ne peut être faite de ce site et de l'ensemble de son contenu : textes, documents et images sans l'autorisation expresse de Developpez LLC. Sinon, vous encourez selon la loi jusqu'à 3 ans de prison et jusqu'à 300 000 E de dommages et intérêts. Cette page est déposée à la SACD.
Vous avez déniché une erreur ? Un bug ? Une redirection cassée ? Ou tout autre problème, quel qu'il soit ? Ou bien vous désirez participer à ce projet de traduction ? N'hésitez pas à nous contacter ou par MP !
 
 
 
 
Partenaires

Hébergement Web