- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我添加了一个片段以使其更易于理解。
此代码片段仅在鼠标悬停时绘制,但我希望它仅在您单击并同时移动时绘制。
我尝试使用下面的代码来执行此操作,但它不起作用。
$(document).on('mouseover click','#canvas', function(event){
if(event.type == "mouseover" && event.type == "click"){
alert("e");
}
});
//开始片段
var canvas = document.getElementById('canvas');
var context = canvas.getContext('2d');
$("#canvas").mousemove(function(arg) {
context.fillStyle = "#1477CC";
var pos = getMousePos(canvas, arg);
context.beginPath();
context.arc(pos.x+50,pos.y,5,0,2*Math.PI);
context.fill();
});
function getMousePos(canvas, e) {
var rect = canvas.getBoundingClientRect();
return {
x: e.clientX - rect.left,
y: e.clientY - rect.top
};
}
//Clear
$("#clear").click(function() {
var c = document.getElementById("canvas");
var ctx = c.getContext("2d");
ctx.fillStyle = "#FFFFFF";
ctx.fillRect(0,0,380,300);
});
#canvas{
border: 1px solid black;
}
#clear:hover{
cursor: pointer;
text-decoration: underline;
}
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<canvas id="canvas">
</canvas>
<div onclick="clear();" id="clear">
Clear
</div>
最佳答案
按照建议,您可以添加一个标志来启用绘图:
var enableDraw = false;
$("#canvas").mousedown(function(arg) {
enableDraw = true;
});
$("#canvas").mouseup(function(arg) {
enableDraw = false;
});
$("#canvas").mousemove(function(arg) {
if(enableDraw){
context.fillStyle = "#1477CC";
var pos = getMousePos(canvas, arg);
context.beginPath();
context.arc(pos.x+50,pos.y,5,0,2*Math.PI);
context.fill();
}
});
关于javascript - 在 Canvas 上绘图 : mouseover and mouseclick,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27569431/
到目前为止,我的 mouseClicked() 方法使用 getX() 和 getY()。查看用户是否单击肺部图片。然而,通过使用 x 和 y,成功的“区域”是一个盒子,而不是肺部的形状。因此,单击肺
private JTable getTRent() { if (tRent == null) { ... tRent.addMouseListener(new MouseAda
经过 2 个小时的搜索,我真的找不到为什么我的代码不起作用,所以我想知道你是否可以提供帮助。 当我按下按钮时,我想看到的只是“点击”。我的类 MouseInput 实现了 MouseListener
所以我本质上正在开发一个交易或不交易的java游戏,现在我试图让图像图标在用户点击的地方消失。因此,我有一个 6 x 6 的“金属公文包”(casesArray) 图像图标数组,但无论用户单击何处,只
这是我第一次用 Java 编写游戏。我正在制作一款角色扮演游戏。我已经成功地使用 KeyListener 函数用箭头键移动我的角色。但是,当在窗口中单击鼠标时,我一直试图将角色移向鼠标。我已经发现它可
我正在尝试编写一个寻路迷宫算法,以尝试将 A* 实现到 JPanel 接口(interface)中。代码如下。如您所见,我使用随机数生成器随机生成迷宫方 block 的颜色。以下是源代码的基本实现:
这似乎应该有效,但实际上无效。我在 SWITCH 语句上设置了调试停止。此事件仅在左键单击时触发。没有任何反应,方法不会在中键或右键单击时触发。有任何想法吗?附言我已经尝试过使用 MouseUp 和
我有一个单元格对象的二维数组,其中包含其“tileCode”的字符串变量,当我使用键盘设置 Activity 图 block 代码,然后单击二维数组中所需的单元格时,它应该更改该单元格的tileCod
我正在制作一个 GUI 配对猜谜游戏,带有 9x12 面板,每个面板中保存一个随机数。我已经做到了,当您将鼠标悬停在每个单独的面板上时,它会从红色变为黄色,并在鼠标离开面板区域后变回红色。我现在的问题
public class ControllerGui { private JFrame frame; private JTextField textField; private JTextField
我正在扩展 JButton 类并使用 ImageIcon 作为按钮背景。我还添加了一个 mouseListener,以便当鼠标悬停在按钮上或按下按钮时可以更改按钮的图像。这一切都工作正常,但问题是,当
我正在使用 java3D 并希望将单击的项目的 ID 传递给我的类。但它没有成功。它可以打印 ID,也可以将其传递给字符串文本。但它在 game.btClicked(text); 行中显示 nullP
我尝试制作一个程序,每次单击时都会创建一个视觉效果,但它不起作用,因此我将代码精简为不起作用的示例。起初我认为问题是我没有绘图函数,因此处理没有搜索事件,但是当我添加 println 时它仍然没有触发
我想知道是否有一个选项可以使用java机器人类来单击像素之间。我在网上没有找到任何相关信息。 示例:robot.mousePress(float x, float y); 最佳答案 我认为您不能在 m
有没有一种方法可以以秒或毫秒为单位计算单击鼠标按钮和释放鼠标按钮之间的时间。 我使用了此功能,但不适合我 public void mouseClicked (MouseEvent me) { l
所以我对如何从另一个组件的 mouseClicked 方法访问其他屏幕组件/变量(我不知道如何调用它们,但是像文本框、按钮等)有点困惑。例如,假设单击一个按钮后,另一个按钮就会被禁用。我的意思是,在这
我使用 JPanel 为 Game Of Life 制作 GUI,我的类扩展了 JFrame 并实现了 MouseListener,但是当我单击 JLabel 时,MouseListener 只工作一
我正在编写一个程序,当我单击时,它将移动一个矩形。我有一个函数 move(),它可以将矩形向下移动 100 倍一个像素,并使用 pause(20) 在每次移动之间等待 20 毫秒。当我在 run()
我在窗体上有一个带有 MouseClick 事件的面板。问题是每次单击面板时都不会触发 MouseClick 事件。它跳过点击时非常随机。 我想我可以改用 MouseDown 和 MouseUp 事件
你好我读过可以像方法一样引发事件。嗯,它适用于我的自定义事件(我创建了一个委托(delegate),事件,我可以通过调用它来引发事件)。但是,我无法手动引发 MouseClick 等事件,它一直说它必
我是一名优秀的程序员,十分优秀!