js 图片区域可点击,适配移动端,图片大小随意改变

实现图片区域可点击,实际上使用map是可以的,但是适配效果并不好,图片只能是固定大小的值,而且点都被写死了。

在这里,我使用的js基于canvas写的一个小工具。可以圈出你需要点击的部分,然后生成一串json,在预览页面就可以看见效果了;

在实际应用中,只要用工具处理一下图片,再把数据存入数据库,就很方便了;

使用工具时,先上传图片。然后就可以圈了,圈完一定要记得,点击保存数据,,,接着就可以预览了,预览点击的效果,可以看控制台,

首先是工具

首先工具的html

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<style type="text/css">
			*{
				padding: 0;
				margin: 0;
				font-family: "微软雅黑";
			}
			.hide{
				display: none;
			}
			canvas{
				border: 1px solid red;
				display: block;
				margin: 0 auto;
				background-position: 0 0;
				background-repeat: no-repeat;
				background-size: 100% 100%;

			}
			.cover{
				position: absolute;
				top: 0;
				left: 0;
				width: 100%;
				height: 100%;
				background: rgba(0,0,0,0.4);
			}
			.cover p{
				text-align: center;
			}
			.btn{
				width: 800px;
				margin: 0 auto;
				padding-top: 10px;
			}
			.btn p{
				padding-bottom: 10px;
			}
			a{
				text-decoration: none;
				color: #000;
			}
			button{
				line-height: 30px;
				padding: 0 10px;
				cursor: pointer;
				border-radius: 4px;
				background: #449d44;
				color: #fff;
				border: none;
			}
		</style>
	</head>
	<body>
		<div class="btn">
			<p>
				<button onclick="saveData()">保存数据</button>
				<button onclick="getData()">导入数据</button>
				<button onclick="seeData(true)">查看数据</button>
				<a href="preview.html" target="_blank"><button>预览效果</button></a>
			</p>
			<p>
				<input type="file" name="imgload" id="imgload" value="上传图片" />
			</p>
			<p>
				<button onclick="reduo()">撤销</button>
				<button onclick="clearAll()">清除</button>
			</p>
			<p>
				基础宽度:<input type="text" name="width" id="width" value="800" />
			</p>
			<p>
				基础高度:<input type="text" name="width" id="height" value="600" />
			</p>
		</div>
		<canvas id="canvas" width="800" height="600"></canvas>
		<div class="cover hide">
			<p>
				<span>url地址:</span>
				<input type="text" name="" id="urlAddress" value="" />
			</p>
			<p>
				<span>描述:</span>
				<input type="text" name="dec" id="dec" value="" />
			</p>
			<p>
				<button class="contain">确认</button>
			</p>
		</div>
	</body>
	<script type="text/javascript" src="js/jquery.js"></script>
	<script type="text/javascript" src="js/index.js"></script>
</html>

 

接着是工具的js代码

var canvas = document.getElementById(‘canvas‘);
var ctx = canvas.getContext(‘2d‘);
ctx.lineWidth = 1;
ctx.strokeStyle="green";
/*ctx.beginPath();
ctx.moveTo(10, 100);
ctx.lineTo(300,100);
ctx.stroke();
ctx.closePath();*/
var run = false;
var moduleList = [];
var path = [];
var $baseImg = ‘‘;

var $cover = $(".cover");
var $urlAddress = $(‘#urlAddress‘);
var $dec = $("#dec");

var $baseWidth = $(‘#width‘);
var $baseHeight = $(‘#height‘);

canvas.onmousedown = function(e){
	//console.log(e.clientX);
	//console.log(e.offsetX);
	ctx.beginPath();
	ctx.moveTo(e.offsetX, e.offsetY);
	path.push({
		x:e.offsetX,
		y:e.offsetY
	});
	run = true;
}

canvas.onmousemove = function(e){
	//var x = e.offsetX;
	if(run){
		ctx.lineTo(e.offsetX, e.offsetY);
		ctx.stroke();
		path.push({
			x:e.offsetX,
			y:e.offsetY
		});
	}
}
canvas.onmouseup = function(e){
	run = false;
	ctx.closePath();
	if(path.length > 10){
		$cover.removeClass(‘hide‘);
	}else{
		path = [];
	}
}

//保存数据
function saveData(){
	var data = {
		"dec":"图片点击",
		"version":"1",
		"img":$baseImg,
		"module":moduleList,
		"baseWidth":$baseWidth.val(),
		"baseHeight":$baseHeight.val()
	}
	console.log(JSON.stringify(data));
	localStorage.setItem("data",JSON.stringify(data));
}
//查看数据
function seeData(flag){
	var data = {
		"dec":"图片点击",
		"version":"1",
		"img":$baseImg,
		"module":moduleList,
		"baseWidth":$baseWidth.val(),
		"baseHeight":$baseHeight.val()
	}
	if(flag){
		console.log(JSON.stringify(data));
	}
	return data;
}

//图片背景
$(‘#imgload‘).on(‘change‘,function(){
		imgToBase64(this.files[0],function(result){
			console.log(result);
			var base64Data = ‘url(‘ + result + ‘)‘;
			$(canvas).css({‘background-image‘: base64Data});
			$baseImg = result;
		});

});

//转化为base64
function imgToBase64(file,callback){
	 var reader = new FileReader();

    reader.onload = function (e) {
        callback(e.target.result);
    };
    reader.readAsDataURL(file); // 读取完后会调用onload方法
}

//确认信息
$cover.on(‘click‘,‘.contain‘,function(){
	if($urlAddress.val() == ‘‘){
		alert(‘地址不能为空‘);
	}else{
		moduleList.push({
			id:getName(),
			path:path,
			url:$urlAddress.val(),
			dec:$dec.val()
		});
		path = [];
		$cover.addClass(‘hide‘);
	}
});

//修改高度和宽度
$baseWidth.on(‘change‘,function(){
	$(canvas).css({‘width‘: $(this).val()});
});
$baseHeight.on(‘change‘,function(){
	$(canvas).css({‘height‘: $(this).val()});
});

//随机获取名称
function getName(){
	var timer = new Date();
	var arr = JSON.stringify(timer).replace(/:|-|"/g ,‘‘).split(‘.‘);
	var str = arr.join(‘‘);
	return str;
}

//导入模板
function getData(){
	var data = JSON.parse(localStorage.getItem("data"));
	if(data){
		moduleList = data.module;;
		$baseImg = data.img;
		drawn(data);
	}else{
		alert(‘没有模板数据.‘);
	}
}

//撤销
function reduo(){
	moduleList.pop();
	ctx.clearRect(0, 0, canvas.width, canvas.height);
	drawn(seeData());
}

//清除所有
function clearAll(){
	moduleList = [];
	ctx.clearRect(0, 0, canvas.width, canvas.height);
}

//给数据,画出来
function drawn(data){
	ctx.clearRect(0, 0, canvas.width, canvas.height);
		var module = data.module;
		var base64Data = ‘url(‘ + data.img + ‘)‘;
		$(canvas).css({‘background-image‘: base64Data});
		$baseWidth.val(data.baseWidth);
		$baseHeight.val(data.baseHeight);
		$(canvas).css({‘width‘: data.baseWidth,‘height‘:data.baseHeight});

		//开始画
		for(var i = 0; i < module.length;i++){
			var path = module[i].path;
			ctx.beginPath();
			ctx.moveTo(path[0].x, path[0].y);
			for(var j = 1; j < path.length; j++){
				ctx.lineTo(path[j].x, path[j].y);
				ctx.stroke();
			}
			ctx.closePath();
		}
}

  

 

最后是preview.html预览

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
		<style type="text/css">
			*{
				padding: 0;
				margin: 0;
			}
			body,html{
				width: 100%;
				height: 100%;
			}
			canvas{
				background-position: 0 0;
				background-repeat: no-repeat;
				background-size: 100% 100%;
				width: 100%;
				height: 100%;
			}
			.wrap{
				border: 1px solid red;
				margin: 0 auto;
				width: 800px;
				height: 600px;
			}
		</style>
	</head>
	<body>
		<div class="wrap">
			<canvas id="canvas" ></canvas>
		</div>

	</body>
	<script type="text/javascript" src="js/jquery.js"></script>
	<script type="text/javascript">

		var $canvas = $(‘#canvas‘);
		var canvas = $canvas[0];	

		var data = JSON.parse(localStorage.getItem("data"));
		var ctx = canvas.getContext(‘2d‘);
			ctx.lineWidth = 1;
			ctx.strokeStyle="rgba(0,0,0,0)";
		var module = data.module;
		var rateWidth = $canvas.width()/data.baseWidth;
		var rateHeight = $canvas.height()/data.baseHeight;
		var base64Data = ‘url(‘ + data.img + ‘)‘;
		$canvas.css({‘background-image‘: base64Data});

		console.log(rateWidth);
		console.log(rateHeight);
		//判断点击了图片的某个地方
		canvas.onclick = function(e){
			 var x = event.pageX - canvas.getBoundingClientRect().left;
        	 var y = event.pageY - canvas.getBoundingClientRect().top;
			for(var i = 0; i < module.length;i++){
				var path = module[i].path;
				ctx.beginPath();
				ctx.moveTo(path[0].x*rateWidth, path[0].y*rateHeight);
				for(var j = 1; j < path.length; j++){
					ctx.lineTo(path[j].x*rateWidth, path[j].y*rateHeight);
				}
				ctx.closePath();
				if(ctx.isPointInPath(x, y)){
					clickCall(module[i]);
					return;
				}
			}
		};

		//点击中了选中的区域
		function clickCall(result){
			console.log(result.dec);
			console.log(result.url);

		}
	</script>
</html>

  

注意引入的js和jauery的路径。。

体验地址:如果需要,联系博主

时间: 2024-10-12 09:55:08

js 图片区域可点击,适配移动端,图片大小随意改变的相关文章

html css 图片居中(水平居中和垂直居中),移动端图片预览

做网站的时候,经常会遇到因图片宽高比率不一致导致图片显示方式有问题. 1.在图片宽高未知的情况下,图片上下左右居中   我以前的博客文章有写过,就不再重复了.博客地址,效果预览地址(欢迎copy) 上面的虽然没问题,但是在图片列表里,图片上下左右不对齐,造成图片列表排版很难看,产品要求宽高定死,也就是下面的第二种方法. 2.在图片宽高未知的情况下,img标签 宽高固定显示(图片会变形) 效果预览地址(欢迎copy) 因为第二种方法,宽高定死,导致图片变形了,反而不美. 产品说:我要图片不失真,又

2018.7.2 如何用js实现点击图片切换为另一图片,再次点击恢复到原图片

<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <meta http-equiv="X-UA-Compatible"

让 jQuery UI draggable 适配移动端

背景: 在移动端,本人要实现对某个元素的拖动,想到使用 jQuery UI 的 draggable 功能.但是发现此插件的拖动只支持PC端,不支持移动端. 原因: 原始的 jQuery UI 里,都是mousedown.mousemove.mouseup来描述拖拽和鼠标的点击事件,而在移动端里,肯定要新添touchstart.touchmove.touchend来描述拖拽和手指的点击事件 实现 demo: <!DOCTYPE html> <html lang="en"

js可视区域图片懒加载

可视区域图片懒加载 实现原理,页面滚动时获取需要懒加载的图片,判断此图片是否在可视区域内,是则设置图片data-src地址为src地址,加载图片. <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>jquery可视区域图片懒加载</title> <script src="http://libs.baidu.com/jquery/2

CSS:点击图片区域上传文件

前端菜鸟,本人目前只能看懂和抄代码.因为参与一个项目需要用到这块样式,于是在网上找到的例子.于是记下来,同时也是方便自己查阅. /*定义图像以及大小*/ .imageFileInput{ width: 200px; height: 200px; position: absolute; background-color: red; /*这里可以换成图片路径(background-image:../img/....)注意图片路径*/ } /*定义上传*/ .fileInput{ height: 10

js 基础篇(点击事件轮播图的实现)

轮播图在以后的应用中还是比较常见的,不需要多少行代码就能实现.但是在只掌握了js基础知识的情况下,怎么来用较少的而且逻辑又简单的方法来实现呢?下面来分析下几种不同的做法: 1.利用位移的方法来实现 首先,我们可以在body中添加一个div并且将宽度设置成百分比(自适应页面),比例具体是相对谁的百分比的话按需求来做,在这里不多说.将图片放入到div 中. 其次,样式部分将img标签全部设置成absolute:以方便定位 最后,js部分说说逻辑,定义两个空数组,第一个数组用来保存初始的显示在页面的图

纯原生js移动端图片压缩上传插件

前段时间,同事又来咨询一个问题了,说手机端动不动拍照就好几M高清大图,上传服务器太慢,问问我有没有可以压缩图片并上传的js插件,当然手头上没有,别慌,我去网上搜一搜. 结果呢,呵呵...诶~又全是基于jquery.zepto的(这句话似乎吐槽次数太多了...),然后我也就不吐槽了, 然后当然是自己做了,先上图: 纯原生js的移动端图片压缩上传插件,不依赖任何库 用法 在html页面中引入input标签,通过自定义属性data-LUploader绑定点击触发的标签id,写法如下: <div cla

1.横向滚动条,要设置两个div包裹. 2. 点击切换视频或者图片. overflow . overflow-x

1.横向滚动条. div.1 > div.2 > img img  img 第一: 设置 div.1 一个固定的宽度 和高度  . 例如宽度 700px;  高度是 120px; 设置 overflow-x 第二; 每个图片的 宽度是 150px, 高度 100px( 比 div.1 小, 要可以显示横向滚动条 第三: 重点 . 设置 div.2 的宽度 .  如果有 10个图片, 每个图片margin-right 为 10px,   那么 div.2 的宽度就是  (150+10)*10 这

写一个判断单点触摸某图片区域的例子。

效果:输出触摸处坐标,并判断是否点击了图片区域. .h 文件 #ifndef __HELLOWORLD_SCENE_H__ #define __HELLOWORLD_SCENE_H__ #include "cocos2d.h" using namespace cocos2d; class HelloWorld : public cocos2d::CCLayer { public: // Here's a difference. Method 'init' in cocos2d-x re