图片热点链接实现,该如何解决

图片热点链接实现
问题描述如下:想做一个报纸在线预览的功能.鼠标移到版面图相应区域点击后,则进入相应的内容页面.就象人民网的网上读报一样.如:http://paper.people.com.cn/rmrbhwb/html/2008-02/15/node_34.htm

前台显示比较容易解决,难的是后台发布的编辑器如何做,我的实现思路是:
将上传的版面图显示在一个编辑页面中,当鼠标在图片上相应区域点击后拖动,就会拉出一个相应的层来(类似于在dw中画图片热点)。鼠标释放后,弹出对话框,输入目标文章网址。而层的位置数据用js获取后存入数据库,作为图片热点区域的坐标。这样依次画出多个热点区域来。

由于本人对js不甚了解,现在遇到的技术难题是:
如何通过js获取鼠标动作和坐标,绘制出相应位置和大小的层(这个层只是为了直观,真正的目的是为了获取特定区域的坐标)。

还望高手们指点。大家有没有人做过类似的项目?

------解决方案--------------------
onMouseDown,onMousemove,onMouseUp事件就可以满足你的需求了。
------解决方案--------------------
记录下坐标和链接,onmousemove判断后跳转
或者将图片切成多个小图片显示
------解决方案--------------------
在HTML中还可以把图片划分成多个热点区域,每一个热点域链接到不同网页的资源。这种效果的实质是把一幅图片划分为不同的热点区域,再让不同的区域进行超链接。这就是影像地图。要完成地图区域超链接要用到三种标签:<img><map><area>下面分别介绍这些标签的用法:

影像地图(Image Map)标签的使用格式:

<img src="图形文件名" usemap="#图的名称">

<!-- 插入图片时要在<img>标记中设置参数usemap="#图的名称" ismap,以表示对图像地图(图的名称)的引用;-->

<map name="图的名称">

<!--用<map>标记设定图像地图的作用区域,并用name属性爲图像起一个名字-->

<area shape=形状 coords=区域座标列表 href="URL资源地址">
......可根据需要定义多少个热点区域
<area shape=形状 coords=区域座标列表 href="URL资源地址">

</map>


【1】shape -- 定义热点形状
shape=rect: 矩形
shape=circle:圆形
shape=poly: 多边形

【2】coords -- 定义区域点的坐标

a.矩形:必须使用四个数字,前两个数字为左上角座标,后两个数字为右下角座标
例:<area shape=rect coords=100,50,200,75 href="/URL">

b.圆形:必须使用三个数字,前两个数字为圆心的座标,最后一个数字为半径长度
例:<area shape=circle coords=85,155,30 href="/URL">

c.任意图形(多边形):将图形之每一转折点座标依序填入
例:<area shape=poly coords=232,70,285,70,300,90,250,90,200,78 href="/URL">

在制作本文介绍的效果时应注意的几点:
   1、在<img>标记不要忘记设置usemap、ismap参数,且usemap的参数值必须与<map>标记中的name参数值相同,也就是说,“图像地图名称”要一致;
   2、同一“图像地图”中的所有热点区域都要在图像地图的范围内,即所有<area>标记均要在<map>与</map>之间;
   3、在<area>标记中的 cords 参数设定的坐标格式要与shape参数设定的作用区域形状配套,避免出现在shape参数设置的矩形作用区域,而在cords 中设置的却是多边形区域顶点坐标的现象出现。

<html>
<head>
<title>影像地图</title>
</head>

<body>
<img src="http://www.cnblogs.com/imge/yxlj.jpg" alt="影像地图" hspace="10" align="left" usemap="#yxdt" border="0">
<map name="yxdt">
<area shape="rect" coords="80,69,180,120" href="http://www.baidu.com/" target="_blank" alt="点击链接到百度搜索">
<area shape="circle" coords="283,95,45" href="http://www.sina.com.cn" target="_blank" alt="点击链接到新浪网站">
</map>
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>&nbsp;</p>
<p><a href="#" onClick="javascript:window.history.back()">返回</a></p>
</body>
</html>