chromium添加一个书签项,并自动显示图标

添加一个书签很简单:

BookmarkModel* model = BookmarkModelFactory::GetForBrowserContext(browser->profile());

const bookmarks::BookmarkNode* node = bookmarks::AddIfNotBookmarked(model, url, title);

两句话即可。麻烦的是怎么设置完书签以后还要显示这个书签对应的网址的favicon。

这个涉及到chromium的icon管理。

chromium把这块写的很复杂,其实真正的原因是chromium是要做成操作系统的,所以对各种icon有个统一的管理。而favicon的获取,需要打开网页,进行解析。所以所以我们需要创建一个webview控件来做这事情:

cpp 复制代码
 views::WebView* webview = g_hidden_web_view;// new views::WebView(browser->profile());

#if 0
  content::WebContentsImpl* web_contents = (content::WebContentsImpl*)webview->GetWebContents();
  new WebContentsBookmarkObserver(web_contents, node, url);

  favicon::CreateContentFaviconDriverForWebContents(web_contents);
  webview->LoadInitialURL(url);
#endif

然后还要记得在DidUpdateFaviconURL这个回调里刷新一下icon:

cpp 复制代码
class WebContentsBookmarkObserver : public content::WebContentsObserver {
public:
  WebContentsBookmarkObserver(WebContents* web_contents, const bookmarks::BookmarkNode* node, const GURL& page_url)
    : WebContentsObserver(web_contents) {
    node_ = node;
    page_url_ = page_url;
  }

  void DidUpdateFaviconURL(content::RenderFrameHost* rfh, const std::vector<blink::mojom::FaviconURLPtr>& candidates) override {
    if (candidates.size() == 0)
      return;

    content::BrowserContext* ctx = rfh->GetBrowserContext();
    BookmarkModel* model = BookmarkModelFactory::GetForBrowserContext(ctx);
    //node_->InvalidateFavicon();
    //model->GetFavicon(node_);

    //page_url_ = rfh->GetManifestURL();

    std::set<GURL> page_urls;
    page_urls.insert(page_url_);
    model->OnFaviconsChanged(page_urls, candidates[0]->icon_url);
  }
  const bookmarks::BookmarkNode* node_ = nullptr;
  GURL page_url_;
};

当然,如果不需要在线获取favicon,而是设置一个本地的icon:

cpp 复制代码
  favicon::FaviconService* service = FaviconServiceFactory::GetForProfile(browser->profile(), ServiceAccessType::IMPLICIT_ACCESS);

  gfx::Image image = CreateSkBitmap(SK_ColorRED, 16);
  service->SetOnDemandFavicons(url, url2, favicon_base::IconType::kFavicon, image, base::BindOnce(OnFaviocnAddFinish));
相关推荐
编程猪猪侠6 小时前
解决yarn install 报错 error \node_modules\electron: Command failed.
前端·javascript·electron
zooooooooy18 小时前
Electron打包ARM环境deb包
后端·electron
red润2 天前
浏览器离屏渲染 vs. Electron离屏渲染——核心区别与应用场景
前端·electron·canvas
OpenIM3 天前
Electron Demo 的快速编译与启动
前端·javascript·electron
柚子a3 天前
Electron主进程渲染进程间通信的方式
electron
柚子a3 天前
electron使用remote报错
electron
DevUI团队4 天前
Electron 入门学习指南:快速搭建跨平台桌面应用
前端·javascript·electron
RedHood4 天前
鸿蒙投屏实现
electron·harmonyos
黑金IT5 天前
如何在 Electron 应用中安全地进行主进程与渲染器进程通信
服务器·安全·electron
培根芝士5 天前
Electron打包支持多语言
前端·javascript·electron