Add API to capture a page into file.
This commit is contained in:
parent
9ad3b7939f
commit
36ecb35cb1
2 changed files with 49 additions and 0 deletions
|
@ -29,6 +29,7 @@
|
||||||
#include "common/api/api_messages.h"
|
#include "common/api/api_messages.h"
|
||||||
#include "common/options_switches.h"
|
#include "common/options_switches.h"
|
||||||
#include "ipc/ipc_message_macros.h"
|
#include "ipc/ipc_message_macros.h"
|
||||||
|
#include "ui/gfx/codec/png_codec.h"
|
||||||
#include "ui/gfx/point.h"
|
#include "ui/gfx/point.h"
|
||||||
#include "ui/gfx/rect.h"
|
#include "ui/gfx/rect.h"
|
||||||
#include "ui/gfx/size.h"
|
#include "ui/gfx/size.h"
|
||||||
|
@ -198,6 +199,18 @@ bool NativeWindow::SetIcon(const std::string& str_path) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void NativeWindow::CapturePage(const gfx::Rect& rect,
|
||||||
|
const base::FilePath& path,
|
||||||
|
const CapturePageCallback& callback) {
|
||||||
|
GetWebContents()->GetRenderViewHost()->CopyFromBackingStore(
|
||||||
|
rect,
|
||||||
|
gfx::Size(),
|
||||||
|
base::Bind(&NativeWindow::OnCapturePageDone,
|
||||||
|
base::Unretained(this),
|
||||||
|
path,
|
||||||
|
callback));
|
||||||
|
}
|
||||||
|
|
||||||
void NativeWindow::CloseWebContents() {
|
void NativeWindow::CloseWebContents() {
|
||||||
bool prevent_default = false;
|
bool prevent_default = false;
|
||||||
FOR_EACH_OBSERVER(NativeWindowObserver,
|
FOR_EACH_OBSERVER(NativeWindowObserver,
|
||||||
|
@ -374,6 +387,29 @@ void NativeWindow::Observe(int type,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void NativeWindow::OnCapturePageDone(const base::FilePath& filename,
|
||||||
|
const CapturePageCallback& callback,
|
||||||
|
bool succeed,
|
||||||
|
const SkBitmap& bitmap) {
|
||||||
|
if (!succeed) {
|
||||||
|
callback.Run(false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<unsigned char> data;
|
||||||
|
bool encoded = gfx::PNGCodec::EncodeBGRASkBitmap(bitmap, true, &data);
|
||||||
|
if (!encoded) {
|
||||||
|
callback.Run(false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
int written = file_util::WriteFile(
|
||||||
|
filename,
|
||||||
|
reinterpret_cast<const char*>(&data[0]),
|
||||||
|
data.size());
|
||||||
|
callback.Run(written > 0);
|
||||||
|
}
|
||||||
|
|
||||||
void NativeWindow::OnRendererMessage(const string16& channel,
|
void NativeWindow::OnRendererMessage(const string16& channel,
|
||||||
const base::ListValue& args) {
|
const base::ListValue& args) {
|
||||||
AtomBrowserMainParts::Get()->atom_bindings()->OnRendererMessage(
|
AtomBrowserMainParts::Get()->atom_bindings()->OnRendererMessage(
|
||||||
|
|
|
@ -108,6 +108,13 @@ class NativeWindow : public brightray::DefaultWebContentsDelegate,
|
||||||
virtual void RestartHangMonitorTimeout();
|
virtual void RestartHangMonitorTimeout();
|
||||||
virtual bool SetIcon(const std::string& path);
|
virtual bool SetIcon(const std::string& path);
|
||||||
|
|
||||||
|
// Captures the page with |rect| and saves the image to |path|, |callback|
|
||||||
|
// would be called when capturing is done.
|
||||||
|
typedef base::Callback<void(bool succeed)> CapturePageCallback;
|
||||||
|
virtual void CapturePage(const gfx::Rect& rect,
|
||||||
|
const base::FilePath& path,
|
||||||
|
const CapturePageCallback& callback);
|
||||||
|
|
||||||
// The same with closing a tab in a real browser.
|
// The same with closing a tab in a real browser.
|
||||||
//
|
//
|
||||||
// Should be called by platform code when user want to close the window.
|
// Should be called by platform code when user want to close the window.
|
||||||
|
@ -184,6 +191,12 @@ class NativeWindow : public brightray::DefaultWebContentsDelegate,
|
||||||
private:
|
private:
|
||||||
void RendererUnresponsiveDelayed();
|
void RendererUnresponsiveDelayed();
|
||||||
|
|
||||||
|
// Called when CapturePage has done.
|
||||||
|
void OnCapturePageDone(const base::FilePath& filename,
|
||||||
|
const CapturePageCallback& callback,
|
||||||
|
bool succeed,
|
||||||
|
const SkBitmap& bitmap);
|
||||||
|
|
||||||
void OnRendererMessage(const string16& channel,
|
void OnRendererMessage(const string16& channel,
|
||||||
const base::ListValue& args);
|
const base::ListValue& args);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue