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));
相关推荐
Mr_兔子先生5 小时前
2025盛夏版:基于electron37+vite7的Vue桌面客户端保姆教程
vue.js·electron·vite
前端工作日常2 天前
平台价值与用户规模的共生关系
electron·测试·puppeteer
阿夹克斯2 天前
告别Vite脚手架局限!MixOne Beta测试招募:你的需求,我们来实现
electron
深职第一突破口喜羊羊2 天前
记一次electron开发插件市场遇到的问题
javascript·electron
cypking2 天前
electron中IPC 渲染进程与主进程通信方法解析
前端·javascript·electron
cypking3 天前
解决electron+vue-router在history模式下打包后首页空白问题
javascript·vue.js·electron
Mr_兔子先生4 天前
2025盛夏版:基于electron37+vite7的React桌面客户端保姆教程
react.js·electron·vite
小圣贤君5 天前
在写作软件中画地图,Canvas 绘图在地图设计中应用
vue.js·electron·写作·canvas·绘图
屋昂仼5 天前
解决 Electron 中 window.open 打开新窗口的各种“坑”
前端·javascript·electron
牛马喜喜5 天前
记一次electron开发插件市场遇到的问题
前端·electron