- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我对 jQuery 有点粗鲁,所以请多多包涵。 :)
代码的目标是在点击时,如果方 block 是白色的,用选定的颜色给它着色。如果它是选定的颜色,请将其设置回白色。它有效,除非从一种颜色变为另一种颜色,中间有一个白色点。例如:
当我做黑色 > 蓝色时,它处理为黑色 > 白色 > 蓝色。
这是我的代码片段
$(pixelCanvas).on("click", "td", function(){
let background = $(this).css("background-color");
let isEmpty = !background || background === "rgb(255, 255, 255)" ||
background === "#ffffff";
let isNotColor = background !== color;
if(isEmpty){
$(this).css("background-color", color);
} else if(isNotColor){
$(this).css("background-color", color);
} else {
$(this).css("background-color", "#ffffff");
}
});
这是我的codepen链接
https://codepen.io/ashleighc207/pen/QaezPO
提前致谢!
最佳答案
于是我找到了一个将rgb转成hex的函数here并将其用于您的背景颜色。它似乎工作正常,但我不确定它是否会在所有浏览器和操作系统上一致地工作,在 Windows 10 上测试过 Chrome。无论哪种方式,它都应该让你知道你需要关注什么,并确保你的颜色代码都采用相同的格式。
/* global $ */
$(document).ready(function() {
let color = $("#colorPicker").val();
let row = $(".row");
let column = $(".column");
let submitBtn = $("#submitBtn");
let pixelCanvas = $("#pixel_canvas");
let mouseDown = false;
function makeGrid(height, width) {
for (let i = 0; i < height; i++) {
let tableRow = $("<tr class=\"row\"></tr>");
for (let j = 0; j < width; j++) {
tableRow.append("<td class=\"column\"></td>");
}
pixelCanvas.append(tableRow);
}
}
function removeGrid() {
$("tr").remove();
}
function rgbToHex(rgb) {
var a = rgb.split("(")[1].split(")")[0].split(",");
return "#" + a.map(function(x) {
x = parseInt(x).toString(16);
return (x.length == 1) ? "0" + x : x;
}).join("");
}
$(submitBtn).on("click", function(evt) {
evt.preventDefault();
removeGrid();
let inputHeight = $("#inputHeight").val();
let inputWidth = $("#inputWidth").val();
makeGrid(inputHeight, inputWidth);
});
$("#colorPicker").on("change", function() {
color = $("#colorPicker").val();
});
$(pixelCanvas).on("mousedown", function() {
mouseDown = true;
});
$(pixelCanvas).on("click", "td", function() {
let background = rgbToHex($(this).css("background-color"));
let isEmpty = !background || background === "rgb(255, 255, 255)" ||
background === "#ffffff";
let isNotColor = background !== color;
console.log(color);
console.log(background);
console.log(isEmpty);
console.log(isNotColor);
if (isEmpty) {
$(this).css("background-color", color);
} else if (isNotColor) {
$(this).css("background-color", color);
} else {
$(this).css("background-color", "#ffffff");
}
});
$(pixelCanvas).on("mouseup", function() {
mouseDown = false;
});
$(pixelCanvas).on("mousemove", "td", function(evt) {
evt.preventDefault();
if (mouseDown) {
$(this).attr("style", `background-color: ${color}`);
}
});
});
body {
margin: 0px;
margin-bottom: 500px; /* added this cause logs are blocking screen */
}
.container {
text-align: center;
font-family: Century Gothic, helvetica;
display: flex;
flex-direction: column;
height: 20%;
min-height: 100vh;
}
.row,
.column {
background-color: #FFFFFF;
}
.content {
display: flex;
text-align: center;
height: 80%;
padding: 2%;
justify-content: space-around;
}
.column-1 {
display: flex;
order: 1;
flex: 0 1 20%;
flex-direction: column;
}
.column-2 {
display: flex;
order: 2;
flex: 0 1 80%;
flex-direction: column;
}
.heading-one {
flex: 0 1 100%;
font-family: Century Gothic, helvetica;
font-size: 70px;
margin: 0px;
height: 10%;
}
.form-group {
padding: 5% 0%;
}
#pixel_canvas,
.row,
.column {
border: 1px solid black;
}
#pixel_canvas {
border-collapse: collapse;
margin: 0 auto;
}
.row {
height: 20px;
}
.column {
width: 20px;
}
#inputHeight,
#inputWidth {
width: 6em;
}
#submitBtn,
#colorPicker {
border-radius: 5px;
}
#colorPicker {
border: none;
box-shadow: 1px 1px 1px #777777;
}
<!DOCTYPE html>
<html>
<head>
<title>Pixel Art</title>
<link rel="stylesheet" href="stylesheet.css">
</head>
<body class="container">
<h1 class="heading-one">Pixel Art Maker</h1>
<div class="content">
<div class="column-1">
<h2 class="heading-two">Choose Pixel Grid Size</h2>
<form id="sizePicker">
<div class="form-group">
<label for="input_height">
Grid Height:
</label>
<input type="number" id="inputHeight" name="height" min="1" max="50" value="1">
</div>
<div class="form-group">
<label for="input_width">
Grid Width:
</label>
<input type="number" id="inputWidth" name="width" min="1" value="1">
<div class="form-group">
<input type="submit" id="submitBtn" value="Create!">
</div>
</div>
</form>
<h2 class="heading-two">Pick A Color</h2>
<div class="form-group">
<input type="color" id="colorPicker">
</div>
</div>
<div class="column-2">
<h2 class="heading-two">Design Canvas</h2>
<table id="pixel_canvas"></table>
</div>
</div>
<script type="text/javascript" src="//ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<script type="text/javascript" src="designs.js"></script>
</body>
</html>
编辑:在底部添加边距,这样日志就不会阻止输入和指定的浏览器和操作系统。
关于jQuery 在点击时更改 <td> 背景的颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48574466/
我正在阅读 java swing,但在理解它时遇到问题。 Color 是一个类吗? Color[] col= {Color.RED,Color.BLUE}; 这在java中是什么意思? 最佳答案 Is
我正在研究用 python 编写的 pacman 程序。其中一个模块是处理吃 bean 游戏的图形表示。这当然是一些主机颜色。列表如下: GHOST_COLORS = [] ## establishe
本网站:http://pamplonaenglishteacher.com 源代码在这里:https://github.com/Yorkshireman/pamplona_english_teache
我最近将我的手机更新为 Android Marshmallow 并在其上运行了我现有的应用程序,但注意到颜色行为有所不同:将更改应用到 View (可绘制)的背景时,共享相同背景的所有 View (引
所有 X11/w3c 颜色代码在 Android XML 资源文件格式中是什么样的? I know this looks a tad ridiculous as a question, but giv
试图让 ffmpeg 创建音频波形,同时能够控制图像大小、颜色和幅度。我已经尝试过这个(以及许多变体),但它只是返回无与伦比的 "。 ffmpeg -i input -filter_complex "
我很好奇你是否有一些关于 R 中颜色酿造的技巧,对于许多独特的颜色,以某种方式使图表仍然好看。 我需要大量独特的颜色(至少 24 种,可能需要更多,~50 种)用于堆叠区域图(所以不是热图,渐变色不起
我看到的许多 WPF 示例和示例似乎都有硬编码的颜色。这些指南 - http://msdn.microsoft.com/en-us/library/aa350483.aspx建议不要硬编码颜色。在构建
我想更改文件夹的默认蓝色 如何设置? 最佳答案 :hi Directory guifg=#FF0000 ctermfg=red 关于Vim NERDTree 颜色,我们在Stack Overflow上
是否有关于如何将任意字符串哈希为 RGB 颜色值的最佳实践?或者更一般地说:3 个字节。 你问:我什么时候需要这个?这对我来说并不重要,但想象一下任何 GitHub 上的那些管图 network pa
我正在尝试将默认颜色设置为自定义窗口小部件。 这是有问题的代码。 class ReusableCard extends StatelessWidget { ReusableCard({this.
import javax.swing.*; import javax.swing.table.DefaultTableCellRenderer; import javax.swing.table.Ta
我有一个 less 文件来定义一堆颜色/颜色。每个类名都包含相关颜色的名称,例如 .colourOrange{..} 或 .colourBorderOrange{..} 或 navLeftButtOr
我有一个RelativeLayout,我需要一个黑色背景和一个位于其中间的小图像。我使用了这段代码: 其中@drawable/bottom_box_back是: 这样我就可以将图像居中了。但背
我需要设置 浅色 的 JPanel 背景,只是为了不覆盖文本(粗体黑色)。 此刻我有这个: import java.util.Random; .... private Random random =
我正在尝试制作一个自定义文本编辑器,可以更改特定键入单词的字体和颜色。如何更改使用光标突出显示的文本的字体和/或颜色? 我还没有尝试过突出显示部分。我尝试获取整个 hEdit(HWND) 区域并更改字
我想改变我整个应用程序的颜色。 在我的 AndroidManfiest.xml 中,我有正确的代码: 在 values 文件夹中,我有 app_theme.xml: @style/MyAc
是否可以使用 android 数据绑定(bind)从 xml 中引用颜色? 这很好用: android:textColor="@{inputValue == null ? 0xFFFBC02D : 0
有没有办法在 Android 应用程序中设置“空心”颜色? 我的意思是我想要一个带有某种背景的框,而文本实际上会导致背景透明。换句话说,如果整个 View 在蓝色背景上,文本将是蓝色的,如果它是红色的
我用CGContextStrokePath画在白色背景图片中的一条直线上,描边颜色为红色,alpha为1.0画线后,为什么点不是(255, 0, 0),而是(255, 96, 96)为什么不是纯红色?
我是一名优秀的程序员,十分优秀!