mpr*_*mpr 6 qt5 qtwebengine qwebengineview qwebenginepage
我已经部分工作,但我面临几个困难:
1)看来QWebEnginePage需要QWebEngineView。(请参阅此处的 setView() 方法:https://code.woboq.org/qt5/qtwebengine/src/webenginewidgets/api/qwebenginepage.cpp.html)
2) QWebEngineView 除非可见,否则不会呈现。
3) 似乎没有任何方法可以检测视图的哪些区域受到了影响。
我想确认一下新 API 是否可以做到这一点?旧的 QT WebKit API 提供了一种实现此目的的方法。
是的,有可能,
Scene = std::make_unique<QGraphicsScene>();
HiddenView = std::make_unique<QGraphicsView>(mScene.get());
WebView = std::make_unique<QWebEngineView>();
Scene->addWidget(mWebView.get());
WebView->resize(size); //any QSize you like
WebView->load(url); // give your url here
mWebView->show(); //this doesn't actually show, just enables you to render offscreen, see below
ImageData = QImage(size, QImage::Format_ARGB32);
connect(mWebView.get(), &QWebEngineView::loadFinished, this, &ClassA::onViewLoaded);
Run Code Online (Sandbox Code Playgroud)
然后,在 onViewLoaded 中我们调用 update() 方法来定期渲染。请注意,“this”是 ClassA 的对象。
void ClassA::onViewLoaded(){
Timer = std::make_unique<QTimer>();
connect(mTimer.get(), &QTimer::timeout, , &SpaOffscreenRender::update);
mTimer->start(30); //every 30 miliseconds
}
Run Code Online (Sandbox Code Playgroud)
最后你渲染成这样:
void ClassA::update()
{
QPainter painter(&ImageData);
WebView->page()->view()->render(&painter);
painter.end();
}
Run Code Online (Sandbox Code Playgroud)
ImageData 有你想要的:)
| 归档时间: |
|
| 查看次数: |
1756 次 |
| 最近记录: |