0

尝试body在此页面上复制此 CSS 定义:

div{

    cursor: url(""), auto !important;
    height:200px;
    width:200px;
}
<div>hover</div>

自定义光标有效,但未呈现为视网膜图像。它被渲染为一个模糊的、100% 大尺寸的图像。

有没有办法强制它显示为视网膜图像?(我尝试了 Chrome 和 Safari)

4

2 回答 2

0

这是一些CSS。我刚刚将您的 PNG 转换为 SVG 并调整了它的大小。随意对此进行解码并在 XML 中调整 SVG 的大小。

div{

    cursor: url(""), auto;
    height:200px;
    width:200px;
}
于 2021-05-06T14:18:36.707 回答
-2

是的,使用 SVG 完全可以做到这一点,它可以在任何像素密度、标准 (@1x)、视网膜 (@2x) 甚至 4k 和 8k 显示器 (@3x、@4x+) 的屏幕上以清晰的清晰度显示。

您也不必使用 Base64,不依赖 Base64 可能会更容易。这是一个没有 Base^4 的示例,我只是通过 URL 将光标 SVG 图像拉入其中。我在第一个示例下方还有一个动态 Base64 示例,因此请向下滚动。

div {
  cursor: url('https://assets.codepen.io/1580009/stackoverflow-67356313-cursor.svg'), auto;
  height: 200px;
  width: 200px;
}
<div>hover</div>

如果您希望对您的 SVG 进行 Base64 编码,那也可以,尽管它并不总是高效(可能不是 Base64 SVG)。下面是一个动态使用 Base64 的例子。为了这个示例,我已将 SVG 本身添加到 HTML 的主体中,以及可用于控制光标大小的字段。当您调整输入字段的光标大小时,Base64 字符串将自动为更新的光标大小重新计算新的 Base64 字符串,并在悬停 div 上重写该样式。

const input = document.querySelector('input'),
      svgCursor = document.querySelector('svg#cursor'),
      hoverDiv = document.querySelector('div');

const setCursor = (size = 16) => {
  svgCursor.setAttribute('width', size);
  svgCursor.setAttribute('height', size);
  const base64cursor = window.btoa(new XMLSerializer().serializeToString(svgCursor));
  hoverDiv.style.setProperty('cursor', `url('data:image/svg+xml;base64,${base64cursor}'), auto`);
};
setCursor();

input.addEventListener('change', () => setCursor(input.value));
div {
  margin-top: 20px;
  height: 200px;
  width: 200px;
  border: 2px dashed #f00;
}
svg#cursor {
  display: none;
}
<label>Cursor size: <input value="16" type="number"></label>

<div>hover</div>

<svg version="1.1" id="cursor" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 32 32" style="enable-background:new 0 0 32 32;" xml:space="preserve" width="16" height="16"><polygon fill="#D0CBE7" points="0,0 13,32 17,23 25,32 32,25 23.7,17.1 32,13 "/><g><polygon fill="#EDE9FA" points="24,17 32,13 0,0 29,28 32,25"/></g></svg>

于 2021-05-11T16:32:14.853 回答