点击透明图像像素

2024-04-01

我不希望图像的透明部分可点击。
我发现<map>但坐标以像素为单位,我想做一些响应式的事情。 另一个问题:我找不到为什么第一张图片的底部和第二张图片的顶部之间有一些像素。

https://jsfiddle.net/tsfxy84u/ https://jsfiddle.net/tsfxy84u/

.container {
  width: 90%;
  margin: 0 auto;
  overflow: auto;
}
.left {
  float: left;
}
.right {
  float: right;
}
.resize {
  width: 50%;
}
img {
  width: 50%;
}
.two {
  -webkit-clip-path: polygon(20% 0, 100% 0%, 100% 100%, 0% 100%);
  clip-path: polygon(20% 0, 100% 0%, 100% 100%, 0% 100%);
}
.one {
  -webkit-clip-path: polygon(0 0, 100% 0, 80% 100%, 0% 100%);
  clip-path: polygon(0 0, 100% 0, 80% 100%, 0% 100%);
}
<section class="container">
  <a class="two" href="#"><img src="_img/test.png" alt="image test" /></a>
  <div class="resize left">
    <h1>Mama mia</h1>
    <p>blabla</p>
  </div>
</section>
<section class="container">
  <div class="resize right">
    <h1>Mama mia</h1>
    <p>blabla</p>
  </div>
  <a class="one" href="#"><img src="_img/test.png" alt="image test" /></a>
</section>

非常感谢你的帮助。


打破常规思考问题:

  1. 如果在点击坐标像素 Alpha 通道是透明的 (0)- 暂时隐藏该图像,并获取下一个elementFromPoint(x, y)← 重复•1
  2. 如果阿尔法是不透明- 获取图像数据并显示所有临时隐藏的图像。
  3. 如果目标不是 IMG - 显示所有隐藏图像(未单击可见图像像素)

PS:代替Element.hidden我们可以使用CSSpointer-events: "[none, auto]"

const ctx = document.createElement("canvas").getContext("2d");
let stack = [];

function transPNG(ev, target) {
  if(!target.offsetParent) return;

  // Get click coordinates
  const isImage = /img/i.test(target.tagName),
    x = ev.pageX - target.offsetParent.offsetLeft,
    y = ev.pageY - target.offsetParent.offsetTop,
    w = ctx.canvas.width = target.width,
    h = ctx.canvas.height = target.height;
  let alpha;

  // Draw image to canvas and read Alpha channel value
  if (isImage) {
    ctx.drawImage(target, 0, 0, w, h);
    alpha = ctx.getImageData(x, y, 1, 1).data[3]; // [0]R [1]G [2]B [3]A
  }

  if (alpha === 0) {          // If pixel is transparent...
    target.hidden = 1         // Make image hidden
    stack.push(target);       // Remember
    return transPNG(ev, document.elementFromPoint(ev.clientX, ev.clientY)); // REPEAT
  } else {                    // Not transparent! We found our image!
    stack.forEach(el => (el.hidden = 0)); // Show all hidden elements
    stack = [];               // Reset stack
    console.clear(); console.log(target.getAttribute("alt"));
    // document.location = target.dataset.href; // if you want to navigate to HREF
  }
}

const pngs = document.querySelectorAll("#composite img");
pngs.forEach(img =>img.addEventListener("click", ev => transPNG(ev, ev.currentTarget)));
#composite { position: relative; width: 60px; height: 60px;}
#composite img { position: absolute; top: 0; }
Three overlapping PNG images. Click to explore:<br>
<div id="composite">
  <img alt="Red paint" data-href="page3.html" src=""/>
  <img alt="Black birds" data-href="page2.html" src=""/>
  <img alt="Cute bird" data-href="page1.html" src=""/>
</div>

上面的演示仅适用于 1:1 未转换(使用 CSSobject-fit、浏览器调整大小等)图像。如果这是您的情况,那么您应该考虑改进在画布上绘制精确图像尺寸/位置的逻辑。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

点击透明图像像素 的相关文章

  • 打开图层地图,经纬度获取地址

    我正在尝试获取带有经度和纬度的地址 城市 邮政编码 街道地址 但我不知道如何获取 我正在使用开放图层 当我单击地图的一部分时 会获取该位置的经度和纬度 有人有解决方案吗 div class map div
  • 如何在D3中导入json数据?

    如何在D3中导入json文件 I did d3 json temp json 但是我如何在进一步的代码中访问这个数据集呢 到目前为止我已经尝试过 var data d3 json temp json 但使用 data data 在其余代码中
  • jQuery:在方法上取消绑定 jQuery 2.0

    在 jQuery 1 9 中live 已被弃用 因此新方法变为 document on mouseover blahblahfunc 我无法解除 blahblahfunc 的绑定 通过 unbind mouseover mouseout c
  • 如何在alert()之后给予focus()?

    我有类似的东西
  • RxJS 将三元组中的属性组合到表中

    我有一项服务生成类似于三元组的对象 它们将采用以下格式 country attribute value Example country usa attribute population value 100 country mexico at
  • Ember 未在生产环境中加载某些图像

    我有一个 Ember cli 1 13 应用程序 它在公共目录中存储了很多图像 现在 它将正确加载除特定组件中的图像之外的所有图像 该组件的调用方式如下 list item url list url name List Name price
  • 有没有办法在 Blazor 中隐藏 div?

    我正在使用 Blazor 并且想在按下导航栏切换器图标时隐藏侧边栏 列表项崩溃了 但问题是 div 仍然存在 div class page div class sidebar div class nav top row pl 4 navba
  • JavaScript 中 == 和 === 的区别[重复]

    这个问题在这里已经有答案了 有什么区别 and 在 JavaScript 中 我也见过 and 运营商 还有更多这样的运营商吗 看看这里 http longgoldenears blogspot com 2007 09 triple equ
  • 在 html 中创建子页面 [关闭]

    Closed 这个问题需要多问focused help closed questions 目前不接受答案 假设我有一个网站http www example com http www example com 如何为此页面创建更多子页面 即 w
  • 尝试利用?

    我看到我的 nopCommerce 网站记录了以下搜索 ADw script AD4 alert 202 ADw script AD4 我有点好奇他们想要完成什么 我搜索了一下 似乎是ADw script AD4 以 UTF7 编码为
  • (jQuery) 在 cookie 中单击时保存复选框状态

    关于此功能有很多主题 但我似乎无法让它工作 我在谷歌上搜索了这个具体案例 有一堆链接让我来到这里 但奇怪的是我似乎无法让它们工作 我所做的唯一工作如下 http dl dropbox com u 2238080 a old z htm ht
  • 无法在heroku上推送node.js应用程序

    我尝试在heroku 上推送我的node js 应用程序 但是 无法检测到此应用程序的默认语言 我什至尝试过heroku buildpacks set heroku nodejs 但还是无法推动 Counting objects 31 do
  • 脚本和链接标签的简写 http:// 为 // ?有人以前看过/用过这个吗?

    问题如下 如果您使用 addthis 共享按钮 查看任何网站 一旦您浮动在 addthis 按钮上 并且加载了所有必需的资源 请使用 firebug 或 chrome 检查器查看文档的正文 不是源代码 而是屏幕上的实际文档 对象检查器 你会
  • 监听鼠标事件……除了 div 的溢出:滚动滚动条?

    关于如何监听 mousedown 的任何建议 document exceptdiv 的溢出 滚动滚动条 我不确定滚动条是什么元素is为了参考它 您可以使用以下命令自行检查目标 document on mousedown function e
  • 在客户端将大文件(> 2GB)压缩为 ZIP

    我使用构建上传工具node js and socket io 因为他们通常会上传令人难以置信的巨大文件 而普通的上传表单将无法工作 问题是他们想在发送之前将文件压缩成zip 以提高传输效率 我一直在研究压缩方法 例如JSZip http s
  • Dojo 是否可以与其他 JS 框架结合?

    我们使用 Dojo 1 9 3 作为构建单页面应用程序的 JS 框架 然而 我们在 Dojo 的怪癖上花费了太多时间 因此即使是简单的任务也需要很长时间才能实现 由于缺乏适当的文档 我们经常不得不求助于阅读源代码 然后实施解决方法 我觉得如
  • 使用 php 将 HTML 输出转换为纯文本

    我正在尝试将示例 HTML 输出转换为纯文本 但我不知道如何操作 我使用 file get contents 但我尝试转换的页面返回的结果最相似 raw http localhost guestbook profiles php file
  • 推荐的增长缓冲区的方法?

    假设我正在 Node js 中构造一个可变长度的字符串或一系列字节 buf write 的文档说 https nodejs org api buffer html buffer buf write string offset length
  • JQuery 可拖动图像并保存位置

    好吧 这变得很尴尬 已经搜索并尝试了大约 5 个小时 但我只是在兜圈子 场景很简单 它是用户个人资料的标题图像 可以将其拖动到某个位置 然后将图像的顶部位置保存到数据库中 感谢 Beetroot Beetroot 的 遏制 父级 我开始关注
  • Google Universal Analytics - 命令被忽略

    我正在使用 Google Universal Analytics 来跟踪页面浏览量 当我导航到具有 Google Analytics 网站实时功能的页面时 我可以看到 因此我的代码一定可以正常工作 然而 Chrome 一直在控制台中显示 I

随机推荐