html 画出矩形,鼠标弹起,矩形消失
图片
code
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="utf-8" />
- <title></title>
- <style type="text/css">
- .box {
- border:1px solid black;
- width: 0px;
- height: 0px;
- position: absolute;
- z-index:-;
- }
- div{
- opacity:;
- border:1px solid black;
- width:800px;
- height:500px;
- }
- </style>
- <script type="text/javascript">
- window.onload = function(e) {
- e = e || window.event;
- // startX, startY 为鼠标点击时初始坐标
- var startX, startY;
- // 鼠标按下
- document.onmousedown = function(e) {
- startX = e.pageX;
- startY = e.pageY;
- // 在页面创建 box
- var active_box = document.createElement("div");
- active_box.id = "active_box";
- active_box.className = "box";
- active_box.style.top = startY + 'px';
- active_box.style.left = startX + 'px';
- document.body.appendChild(active_box);
- active_box = null;
- };
- // 鼠标移动
- document.onmousemove = function(e) {
- // 更新 box 尺寸
- if(document.getElementById("active_box") !== null) {
- var ab = document.getElementById("active_box");
- if(e.pageX>startX){
- if(e.pageY>startY){
- active_box.style.top = startY + 'px';
- active_box.style.left = startX + 'px';
- ab.style.width = Math.abs(e.pageX - startX) + 'px';
- ab.style.height = Math.abs(e.pageY - startY) + 'px';
- }else if(e.pageY==startY){
- active_box.style.top = startY + 'px';
- active_box.style.left = startX + 'px';
- ab.style.width = Math.abs(e.pageX - startX) + 'px';
- ab.style.height = Math.abs(e.pageY - startY) + 'px';
- }else{
- active_box.style.top = e.pageY + 'px';
- active_box.style.left = startX + 'px';
- ab.style.width = Math.abs(e.pageX - startX) + 'px';
- ab.style.height = Math.abs(e.pageY - startY) + 'px';
- }
- }else if(e.pageX==startX){
- if(e.pageY>startY){
- active_box.style.top = startY + 'px';
- active_box.style.left = startX + 'px';
- ab.style.width = Math.abs(e.pageX - startX) + 'px';
- ab.style.height = Math.abs(e.pageY - startY) + 'px';
- }else if(e.pageY==startY){
- active_box.style.top = startY + 'px';
- active_box.style.left = startX + 'px';
- ab.style.width = Math.abs(e.pageX - startX) + 'px';
- ab.style.height = Math.abs(e.pageY - startY) + 'px';
- }else{
- active_box.style.top = e.pageY + 'px';
- active_box.style.left = startX + 'px';
- ab.style.width = Math.abs(e.pageX - startX) + 'px';
- ab.style.height = Math.abs(e.pageY - startY) + 'px';
- }
- }else{
- if(e.pageY>startY){
- active_box.style.top = startY + 'px';
- active_box.style.left = e.pageX + 'px';
- ab.style.width = Math.abs(e.pageX - startX) + 'px';
- ab.style.height = Math.abs(e.pageY - startY) + 'px';
- }else if(e.pageY==startY){
- active_box.style.top = e.pageY + 'px';
- active_box.style.left = e.pageX + 'px';
- ab.style.width = Math.abs(e.pageX - startX) + 'px';
- ab.style.height = Math.abs(e.pageY - startY) + 'px';
- }else{
- active_box.style.top = e.pageY + 'px';
- active_box.style.left = e.pageX + 'px';
- ab.style.width = Math.abs(e.pageX - startX) + 'px';
- ab.style.height = Math.abs(e.pageY - startY) + 'px';
- }
- }
- }
- };
- // 鼠标抬起
- document.onmouseup = function(e) {
- if(document.getElementById("active_box") !== null) {
- var ab = document.getElementById("active_box");
- ab.removeAttribute("id");
- // 如果长宽均小于 3px,移除 box
- document.body.removeChild(ab);
- }
- };
- };
- </script>
- </head>
- <body>
- <div></div>
- <p>点击鼠标左键并拖动绘制矩形</p>
- </body>
- </html>
html 画出矩形,鼠标弹起,矩形消失的更多相关文章
- 第15.30节 PyQt编程实战:通过eventFilter监视QScrollArea的widget()的Paint消息画出scrollAreaWidgetContents的范围矩形
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 一.引言 在<PyQt(Python+Qt)学习随笔:QScrollArea滚动区域详解> ...
- OpenCV代码:画出轮廓的外接矩形,和中心点
#include <opencv2/highgui/highgui.hpp> #include <opencv2/imgproc/imgproc.hpp> #include & ...
- opencv2 使用鼠标绘制矩形并截取和保存矩形区域图像
前言 好长时间没写博文了,今天偷偷懒写篇关于opencv2中鼠标响应操作的文章. 鼠标操作属于用户接口设计,以前一直使用Qt来做,但是如果只需要简单的鼠标,键盘操作,直接调用opencv库的函数也未尝 ...
- 在OpenCV中利用鼠标绘制矩形和截取图像的矩形区域
这是两个相关的程序,前者是后者的基础.实际上前一个程序也是在前面博文的基础上做的修改,请参考<在OpenCV中利用鼠标绘制直线> .下面贴出代码. 程序之一,在OpenCV中利用鼠标绘制矩 ...
- H5坦克大战之【画出坦克】
今天是个特殊的日子,圣诞节,也是周末,在这里先祝大家圣诞快乐!喜庆的日子,我们可以稍微放松一下,扯一扯昨天雷霆对战凯尔特人的比赛,这场比赛大威少又双叒叕拿下三双,而且是一个45+11+11的超级三双, ...
- 像画笔一样慢慢画出Path的三种方法(补充第四种)
今天大家在群里大家非常热闹的讨论像画笔一样慢慢画出Path的这种效果该如何实现. 北京-LGL 博客号@ligl007发起了这个话题.然后各路高手踊跃发表意见.最后雷叔 上海-雷蒙 博客号@雷蒙之星 ...
- 纯CSS3画出小黄人并实现动画效果
前言 前两天我刚发布了一篇CSS3实现小黄人动画的博客,但是实现的CSS3动画是基于我在站酷网找到的一张小黄人的jpg格式图片,并自己用PS抠出需要实现动画的部分,最后才完成的动画效果.但是,其实我的 ...
- 使用CSS3画出一个叮当猫
刚学习了这个案例,然后觉得比较好玩,就练习了一下.然后发现其实也不难,如果你经常使用PS或者Flash的话,应该就会知道画个叮当猫是很容易的事,至少我是这么觉得.但是,用CSS3画出来确实是第一次接触 ...
- CSS画出的各种形状图
利用CSS可以画出各种需要的图形目录[1]矩形[2]圆形[3]椭圆[4]直角三角形[5]正三角形[6]平行四边形[7]梯形[8]六角星[9]六边形[10]五角星简单图形 矩形div{ width: 1 ...
- WPF 如何画出1像素的线
如何有人告诉你,请你画出1像素的线,是不是觉得很简单,实际上在 WPF 上还是比较难的. 本文告诉大家,如何让画出的线不模糊 画出线的第一个方法,创建一个 Canvas ,添加一个线 界面代码 < ...
随机推荐
- 字符串最长子串匹配-dp矩阵[转载]
转自:https://blog.csdn.net/zls986992484/article/details/69863710 题目描述:求最长公共子串,sea和eat.它们的最长公共子串为ea,长度为 ...
- jquery closest & parent比较
.closest() .parents() 从当前元素开始 从父元素开始 沿 DOM 树向上遍历,直到找到已应用选择器的一个匹配为止. 沿 DOM 树向上遍历,直到文档的根元素为止,将每个祖先元素添加 ...
- 复习一下property
在面向对象程序里,一个对象不要直接访问另一个对象内部的数据.所以我们使用accessor methods来进行对象内部的数据交互. accessor methods(getters and sette ...
- Java-使用IO流对大文件进行分割和分割后的合并
有的时候我们想要操作的文件很大,比如:我们想要上传一个大文件,但是收到上传文件大小的限制,无法上传,这是我们可以将一个大的文件分割成若干个小文件进行操作,然后再把小文件还原成源文件.分割后的每个小文件 ...
- iOS 新浪微博-1.0框架搭建
项目搭建 1.新建一个微博的项目,去掉屏幕旋转 2.设置屏幕方向-->只有竖向 3.使用代码构建UI,不使用storyboard 4.配置图标AppIcon和LaunchImage 将微博资料的 ...
- ASP.NET Post方式提交
public static string SendMsg(string fxPhone, string fxPassword, string toPhone, string msg) { try { ...
- asp.net本地读取excel正确。但在iis服务器上就报错 未在本地计算机上注册“Microsoft.ACE.OleDb.12.0”提供程序
本地vs2010可以上传ecxel文件.并读取数据,但部署到本地IIS.并访问.则提示: 未在本地计算机上注册“Microsoft.ACE.OleDb.12.0”提供程序 首先:确保安装了Micros ...
- Leetcode: Construct Binary Tree from Preorder and Inorder Transversal
Given preorder and inorder traversal of a tree, construct the binary tree. Note: You may assume that ...
- 持续集成之二:搭建SVN服务器(subversion)
安装环境 Red Hat Enterprise Linux Server release 7.3 (Maipo) jdk1.7.0_80 subversion-1.10.3.tar.gz apr-1. ...
- Hive 体系结构介绍
下面是Hive的架构图. 图1.1 Hive体系结构 Hive的体系结构可以分为以下几部分: (1)用户接口主要有三个:CLI,Client 和 WUI.其中最常用的是CLI,Cli启动的时候,会同时 ...