- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有没有人找到一种有效的方法来检测图像是否具有透明背景和图像内部的白色文本? IE。当此图像在白色背景上显示时,将不会显示。
这里正确的做法是使用不同的图像,这可能是最终的解决方案,尽管首先我想看看这是否可以自动化。在我看来,理想的解决方案是为图像提供一个 CSS 背景,如果图像具有包含白色文本的透明背景,那么图像就会显示出来。
这里的挑战是,什么被归类为白色文本?单个像素为白色或图像的 30% 以上的非透明部分为白色或其他颜色?
有没有人找到可以做到这一点的东西?最好使用 Java 来处理图像并确定是否需要应用背景,以便可以设置某种标志,或者更好的是,我还没有遇到过的不错的 CSS 或 JavaScript 技巧。
最佳答案
HTML/CSS:无论图像的颜色/亮度如何,根本不需要任何编码即可使叠加文本可见的常见技巧是添加文本-阴影:
text-shadow: 0px 0px 3px rgba(0, 0, 0, 1);
只需使用 0px
进行水平/垂直阴影偏移和轻微模糊,这样您实际上会在文本周围得到一个非常不透明的边框。
JS:如果您真的想逐个像素地检查并了解图像部分的亮度/颜色,您的文字将被覆盖.
使用 HTML5 的 Canvas ,您可以在 Canvas 中绘制图像并逐个像素地检查并计算平均 RGB 值并根据此调整文本颜色。即使你做对了,这仍然是一个平均值,当文本颜色太接近时,文本可能仍会渗入图像中。
我想通过一些谷歌搜索,您会找到用 JS 为您执行此操作的 Canvas 包装器库。
Java:与 JS 相同的方法 - 确定图像的哪个矩形将被文本覆盖并获取平均颜色。
使用 BufferedImage
,无论图像类型(jpeg、png、...)如何,您都可以获得内存中的每个像素供您检查。
我会选择速效文本阴影解决方案,这根本不需要编码。 如果您真的需要将图像保存为图像而不是仅在网页上显示给用户,我只会选择 2 或 3。
关于javascript - 如何检测图像是否具有透明背景和白色文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42098227/
我想禁用我的 UIButton,所以我调用: button.enabled = FALSE; 然而,这会使按钮变得透明,我可以看到它下面的元素。我不介意它改变颜色,我只是不希望它是透明的。 我尝试在
一个常规的 NSButton 如果被禁用,它似乎是透明的。 图像显示了一个样式为“push”的按钮 但是,我想禁用没有透明度的按钮。 我试图以编程方式将 alphaValue 设置为 1.0 但似乎
我正在尝试将Memoji从iPhone/Mac转换为具有透明背景的一系列png,以便我可以创建一个 Sprite 表。当按下空格键时,我可以清楚地看到它具有透明背景,但是在运行 ffmpeg -i s
我想创建一个具有部分透明背景的 View (舞台、窗口)。我有一张包含 Alpha channel 的图像 我在JavaFx中使用了这种场景,我必须将场景填充设置为空,并将根节点背景颜色设置为透明。我
我想创建一个具有部分透明背景的 View (舞台、窗口)。我有一张包含 Alpha channel 的图像 我在JavaFx中使用了这种场景,我必须将场景填充设置为空,并将根节点背景颜色设置为透明。我
我想将 JDesktopPane 设置为透明,并允许我单击下面的内容(例如桌面图标等)。内部框架应保持不透明,并且能够像当前一样在屏幕周围重新定位。有什么想法吗? package test1;
我知道我不是第一个提出此类问题的人,但我认为我的问题有点不同。 我在 MS Paint 上绘制了一个 png 图像,它是一个播放器,当我使用图形对象绘制图像时,我希望图像的背景是透明的。我尝试了一些带
我在 Mac 的 swift 项目中想使用单选按钮,但与我的背景颜色相同。如何将背景设置为不透明或更改背景颜色? 最佳答案 我找到了解决此问题的方法。将单选按钮的文本设置为“”,将 rb 添加到水平堆
我无法将我的相对布局设置为透明。我尝试了很多不同的方法,从类中自定义 View ,添加 android:background="@android:color/transparent"等。它们要么像下图
在 Storyboard中,我创建了一个 ![UINavigationController] 及其 Root View Controller UIViewcontroller。在工具栏中,我有一个分段
我必须让我的导航栏透明,我试过这段代码: self.navigationController?.navigationBar.setBackgroundImage(UIImage(), for: UIB
我注意到,如果我将 View 背景颜色设置为透明,则在 segue 过渡结束后背景颜色会变成黑色(我猜这是默认的“视口(viewport)”颜色)。 我可以改变吗?当然,我可以将颜色从透明更改为紫色,
嘿,有没有可能让滚动条“隐藏”,我不想使用 overflow-y: hidden就像背景:透明或类似的东西 最佳答案 Here您会找到有关如何仅使用 CSS 隐藏滚动条的说明。 在第二个example
默认情况下,背景显示为白色。是否可以通过任何方式将其背景颜色更改为透明..? (function() { var cx = '005519348941191855053:d0uziw7c
我正在尝试添加一个在 div 的左右边缘具有透明度/淡出的嵌入框阴影。我设法添加了一个普通的嵌入框阴影,但我不知道如何为边缘添加透明度。我该怎么做? 这是我正在努力实现的一个例子。 .contai
如何删除 周围的边框并使其背景透明? 最佳答案 试试这个: border: none; border-color: transparent; 关于html - 透明、无边框的文本输入,我们在Stac
是否可以使 JButton 透明(包括边框)而不是文本?我扩展了 swing 的 JButton 并覆盖了它: @Override public void paint(Graphics g) {
众所周知,要使QWidget/QOpenGLWidget半透明/透明,只需: widget->setAttribute(Qt::WA_TranslucentBackground) 但是,由于 QWin
我想知道如何在 Ubuntu 中为所有应用程序制作透明 Gnome 终端,我知道我们可以为桌面制作透明终端,而不是为所有应用程序制作透明终端。我用谷歌搜索了很多,但找不到任何解决方案。谁能告诉我该怎么
我想让 SWT Canvas 的背景透明,以便可以看到它后面的其他小部件。 我尝试将 alpha 设置为 0 并用矩形填充 Canvas ,并且还使用选项 SWT.NO_BACKGROUND 无济于事
我是一名优秀的程序员,十分优秀!