From 76452bac93c7095b6a5a47c84d0b0571af2df59e Mon Sep 17 00:00:00 2001 From: megabigbug Date: Sat, 26 Jun 2010 23:02:10 +0200 Subject: improve previews: compute preview when webview is deleted => instant preview in closed tab page --- src/webpage.cpp | 12 ++++++++++- src/websnap.cpp | 65 +++++++++++++++++++++++++++++++++++++++++++-------------- src/websnap.h | 22 +++++++++++++++++++ src/webview.cpp | 8 +++++++ 4 files changed, 90 insertions(+), 17 deletions(-) diff --git a/src/webpage.cpp b/src/webpage.cpp index 32b785b4..6b45ad10 100644 --- a/src/webpage.cpp +++ b/src/webpage.cpp @@ -46,6 +46,7 @@ #include "networkaccessmanager.h" #include "adblockmanager.h" #include "urlbar.h" +#include "websnap.h" #include "sslinfodialog_p.h" @@ -211,7 +212,7 @@ WebPage::WebPage(QWidget *parent) WebPage::~WebPage() { - disconnect(); + disconnect(); } @@ -479,6 +480,15 @@ void WebPage::loadFinished(bool ok) { wallet()->fillFormData(mainFrame()); } +/* + if (ok) + { + QPixmap preview = WebSnap::renderVisiblePagePreview(*this); + QString path = WebSnap::imagePathFromUrl(mainFrame()->url().toString()); + QFile::remove(path); + preview.save(path); + } +*/ } diff --git a/src/websnap.cpp b/src/websnap.cpp index c4e50b3c..db0c791c 100644 --- a/src/websnap.cpp +++ b/src/websnap.cpp @@ -102,27 +102,31 @@ QPixmap WebSnap::renderTabPreview(const QWebPage &page, int w, int h) } - -// NOTE please, be careful modifying this. -// You are playing with fire.. -QPixmap WebSnap::renderPagePreview(const QWebPage &page, int w, int h) +// This method tries to render a page currently displayed in a tab without alterate it. +QPixmap WebSnap::renderVisiblePagePreview(const QWebPage &page, int w, int h) { - // prepare page + // save page settings QSize oldSize = page.viewportSize(); - - // find the best size + QPoint oldScrollPosition = page.mainFrame()->scrollPosition(); + + // minimum width + int width = 640; + + // find best width QSize size; - int width = page.mainFrame()->contentsSize().width(); - if (width < 640) + while(page.mainFrame()->scrollBarMaximum(Qt::Horizontal) && width<1920) { - width = 640; + width+=5; + size = QSize(width, width * ((0.0 + h) / w)); + page.setViewportSize(size); } - size = QSize(width, width * ((0.0 + h) / w)); - page.setViewportSize(size); - //render - QPixmap pageImage = WebSnap::render(page, page.viewportSize().width(), page.viewportSize().height()); + // scroll to top + page.mainFrame()->setScrollBarValue(Qt::Vertical, 0); + // render + QPixmap pageImage = WebSnap::render(page, page.viewportSize().width(), page.viewportSize().height()); + // detect scrollbar size int scrollbarWidth = (page.mainFrame()->scrollBarMaximum(Qt::Horizontal) ? 17 : 0); //TODO: detect QStyle size for scrollbars int scrollbarHeight = (page.mainFrame()->scrollBarMaximum(Qt::Vertical) ? 17 : 0); @@ -130,14 +134,43 @@ QPixmap WebSnap::renderPagePreview(const QWebPage &page, int w, int h) // resize image pageImage = pageImage.copy(0, 0, width - scrollbarWidth, size.height() - scrollbarHeight); pageImage = pageImage.scaled(w, h, Qt::KeepAspectRatioByExpanding, Qt::SmoothTransformation); - + // restore page settings page.setViewportSize(oldSize); - + page.mainFrame()->setScrollPosition(oldScrollPosition); + return pageImage; } +QPixmap WebSnap::renderClosingPagePreview(const QWebPage &page, int w, int h) +{ + //scroll to top + page.mainFrame()->setScrollBarValue(Qt::Vertical, 0); + + // reduce as much as possible + page.setViewportSize(QSize(10, 10)); + + return renderPagePreview(page, w, h); +} + + +QPixmap WebSnap::renderPagePreview(const QWebPage &page, int w, int h) +{ + //prepare page + page.mainFrame()->setScrollBarPolicy(Qt::Vertical, Qt::ScrollBarAlwaysOff); + int width = page.mainFrame()->contentsSize().width(); + page.setViewportSize(QSize(width, width * ((0.0 + h) / w))); + + //render + QPixmap pageImage = WebSnap::render(page, page.viewportSize().width(), page.viewportSize().height()); + + // resize image + pageImage = pageImage.scaled(w, h, Qt::KeepAspectRatioByExpanding, Qt::SmoothTransformation); + + return pageImage; +} + QString WebSnap::imagePathFromUrl(const KUrl &url) { diff --git a/src/websnap.h b/src/websnap.h index d1006c18..41db8c71 100644 --- a/src/websnap.h +++ b/src/websnap.h @@ -89,7 +89,29 @@ public: * @return the pixmap snapped from the page */ static QPixmap renderPagePreview(const QWebPage &page, int w = WIDTH, int h = HEIGHT); + + /** + * Snaps a pixmap of size w * h from a visible page + * + * @param page the page to snap + * @param w the image width + * @param h the image height + * + * @return the pixmap snapped from the page + */ + static QPixmap renderVisiblePagePreview(const QWebPage &page, int w = WIDTH, int h = HEIGHT); + + /** + * Snaps a pixmap of size w * h from a visible page + * + * @param page the page to snap + * @param w the image width + * @param h the image height + * + * @return the pixmap snapped from the page + */ + static QPixmap renderClosingPagePreview(const QWebPage &page, int w = WIDTH, int h = HEIGHT); /** * Snaps a pixmap of size w * h from a page for tab preview diff --git a/src/webview.cpp b/src/webview.cpp index afa63028..3f6b289b 100644 --- a/src/webview.cpp +++ b/src/webview.cpp @@ -38,6 +38,7 @@ #include "webpage.h" #include "bookmarksmanager.h" #include "searchengine.h" +#include "websnap.h" // KDE Includes #include @@ -111,6 +112,13 @@ WebView::~WebView() { delete _scrollTimer; disconnect(); + + WebPage* p = page(); + + QPixmap preview = WebSnap::renderClosingPagePreview(*p); + QString path = WebSnap::imagePathFromUrl(p->mainFrame()->url().toString()); + QFile::remove(path); + preview.save(path); } -- cgit v1.2.1 From 627277453810c68f66ac934326df1bea3eed514d Mon Sep 17 00:00:00 2001 From: megabigbug Date: Sun, 27 Jun 2010 11:40:53 +0200 Subject: add comments --- src/webpage.cpp | 7 ++++--- src/websnap.cpp | 9 +++++++-- src/websnap.h | 14 ++------------ 3 files changed, 13 insertions(+), 17 deletions(-) diff --git a/src/webpage.cpp b/src/webpage.cpp index 6b45ad10..9e539f7a 100644 --- a/src/webpage.cpp +++ b/src/webpage.cpp @@ -46,7 +46,7 @@ #include "networkaccessmanager.h" #include "adblockmanager.h" #include "urlbar.h" -#include "websnap.h" +//#include "websnap.h" #include "sslinfodialog_p.h" @@ -212,7 +212,7 @@ WebPage::WebPage(QWidget *parent) WebPage::~WebPage() { - disconnect(); + disconnect(); } @@ -480,7 +480,8 @@ void WebPage::loadFinished(bool ok) { wallet()->fillFormData(mainFrame()); } -/* + +/* this dead code is for try WebSnap::renderVisiblePagePreview() if (ok) { QPixmap preview = WebSnap::renderVisiblePagePreview(*this); diff --git a/src/websnap.cpp b/src/websnap.cpp index db0c791c..29201215 100644 --- a/src/websnap.cpp +++ b/src/websnap.cpp @@ -101,8 +101,13 @@ QPixmap WebSnap::renderTabPreview(const QWebPage &page, int w, int h) return pageImage.scaled(w, h, Qt::IgnoreAspectRatio, Qt::SmoothTransformation); } +/* +// This code is an attempt to render a page currently displayed in a tab without alterate it. +// It currently does not work but can give ideas: +// - activate/disable scrollbars of a webview causes problems => this method try to not do that +// - the viewport and the scroll position must be modified an restored +// - page.setViewportSize(size); does not seem to work when the page is currently displayed in a webview -// This method tries to render a page currently displayed in a tab without alterate it. QPixmap WebSnap::renderVisiblePagePreview(const QWebPage &page, int w, int h) { // save page settings @@ -141,7 +146,7 @@ QPixmap WebSnap::renderVisiblePagePreview(const QWebPage &page, int w, int h) return pageImage; } - +*/ QPixmap WebSnap::renderClosingPagePreview(const QWebPage &page, int w, int h) { diff --git a/src/websnap.h b/src/websnap.h index 41db8c71..3baa01fd 100644 --- a/src/websnap.h +++ b/src/websnap.h @@ -90,20 +90,10 @@ public: */ static QPixmap renderPagePreview(const QWebPage &page, int w = WIDTH, int h = HEIGHT); - /** - * Snaps a pixmap of size w * h from a visible page - * - * @param page the page to snap - * @param w the image width - * @param h the image height - * - * @return the pixmap snapped from the page - */ - static QPixmap renderVisiblePagePreview(const QWebPage &page, int w = WIDTH, int h = HEIGHT); - + // static QPixmap renderVisiblePagePreview(const QWebPage &page, int w = WIDTH, int h = HEIGHT); TODO: try to make this method work => more previews for the urlbar /** - * Snaps a pixmap of size w * h from a visible page + * Snaps a pixmap of size w * h from a page of a tab that is currently closing * * @param page the page to snap * @param w the image width -- cgit v1.2.1