HTML--如何实现通过鼠标事件拖动页面图像(代码)

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head><title>onMouseMove Event Handler</title>
<style type="text/css">
    #camap {position:absolute; left:20; top:120}
    #ormap {position:absolute; left:80; top:120}
    #wamap {position:absolute; left:140; top:120}
</style>
</head>

<script  type="text/javascript">
// global variables used while dragging
var offsetX = 0
var offsetY = 0
var selectedObj
var frontObj
// set document-level event handlers
document.onmousedown = engage
document.onmouseup = release
// positioning an object at a specific pixel coordinate
function shiftTo(obj, x, y) {
    obj.style.pixelLeft = x
    obj.style.pixelTop = y
}
// setting the z-order of an object
function bringToFront(obj) {
    if (frontObj) {
        frontObj.style.zIndex = 0
    }
    frontObj = obj
    frontObj.style.zIndex = 1
}
// set global var to a reference to dragged element
function setSelectedObj() {
    var imgObj = window.event.srcElement
    if (imgObj.id.indexOf("map") == 2) {
        selectedObj = imgObj
        bringToFront(selectedObj)
        return
    }
    selectedObj = null
    return
}
// do the dragging (called repeatedly by onMouseMove)
function dragIt() {
    if (selectedObj) {
        shiftTo(selectedObj, (event.clientX - offsetX), (event.clientY - offsetY))
        return false
    }
}
// set global vars and turn on mousemove trapping (called by onMouseDown)
function engage() {
    setSelectedObj()
    if (selectedObj) {
        document.onmousemove = dragIt
        offsetX = window.event.offsetX - document.body.scrollLeft
        offsetY = window.event.offsetY - document.body.scrollTop
    }
}
// restore everything as before (called by onMouseUp)
function release() {
    if (selectedObj) {
        document.onmousemove = null
        selectedObj = null
    }
}
</script>

<body>
<h1>onMouseMove Event Handler</h1>
<img id="camap" src="d:/bw/n001387.jpg" style="left: 31px; top: 1px"  />
<br />
<img id="ormap" src="d:/bw/n001387.jpg" style="left: 31px; top: 297px" />
<br />
<img id="wamap" src="d:/bw/n001387.jpg" style="left: 31px; top: 184px" />
<br />
</body>
</html> 

<think>好的,用户想在ArcGIS或QGIS中对DEM进行重分类。首先,我需要回忆一下这两个软件中关于重分类的功能和步骤。记得在ArcGIS里,重分类通常是通过Spatial Analyst工具里的Reclassify工具完成的。而在QGIS中,可能使用的是Raster Calculator或者Reclassify by Table之类的插件或处理工具。 用户可能对DEM数据不太熟悉,所以需要先解释什么是重分类。重分类就是将栅格中的数值重新映射到新的类别或范围,比如将高程分成不同的等级,用于分析地形或制作地图。不过,用户已经提到了DEM,所以可能已经了解基本概念,但应用步骤是关键。 接下来,要分步骤说明在两个软件中的操作流程。对于ArcGIS,需要确保Spatial Analyst扩展模块已经启用,然后找到Reclassify工具,选择输入栅格,设置分类规则,比如手动划分间隔或使用分类方法(自然间断点、等间隔等),然后指定输出路径。需要提醒用户注意分类方法的适用场景,比如等间隔适合均匀分布的数据,而自然间断点则根据数据分布自动划分。 对于QGIS,可能步骤稍有不同。QGIS默认可能没有直接的Reclassify工具,但可以通过Raster Calculator使用条件语句来重新分类,或者安装Reclassify插件。比如使用GRASS GIS的r.reclass模块,或者SAGA GIS的重分类工具。需要详细说明每种方法的具体步骤,比如在Processing Toolbox里搜索相关工具,设置旧值到新值的映射表,或者使用表达式进行条件赋值。 另外,用户可能会遇到常见问题,比如分类后数据范围不正确,或者输出结果不显示。这时候需要检查输入数据的值域,确认分类规则是否正确覆盖了所有可能的值,或者检查是否忽略了某些特殊值(如Nodata)。此外,输出格式的选择也可能影响结果,建议使用GeoTIFF等常见格式以确保兼容性。 还要考虑用户的实际应用场景。例如,重分类可能用于洪水模拟,将高程分为淹没区和非淹没区;或者用于土地利用规划,划分不同的坡度等级。不同的应用可能需要不同的分类策略,因此提供一些实例会有帮助。 最后,生成相关问题时,需要围绕DEM处理的其他操作,比如坡度计算、山体阴影生成,或者与其他软件的比较,比如如何选择ArcGIS和QGIS进行这类操作。可能还要涉及数据预处理步骤,比如如何纠正DEM中的错误或填补缺失值。</think>### 如何在 ArcGIS 或 QGIS 中对 DEM 进行重分类? #### **ArcGIS 操作步骤** 1. **启用 Spatial Analyst 扩展** 打开 ArcMap 或 ArcGIS Pro,依次点击 `Customize > Extensions`,勾选 `Spatial Analyst`[^1]。 2. **打开重分类工具** 在 `Toolbox` 中导航至 `Spatial Analyst Tools > Reclass > Reclassify`。 3. **设置参数** - 输入栅格:选择 DEM 数据。 - 分类方法:支持手动划分区间或自动分类(如自然间断点、等间隔)。 - 输出栅格:指定保存路径。 ```python # 示例:通过代码调用工具 arcpy.Reclassify_3d("dem.tif", "VALUE", "0 500 1;500 1000 2;1000 1500 3", "output_reclass.tif") ``` 4. **验证结果** 检查输出栅格的属性表,确认高程值已按规则映射到新类别。 --- #### **QGIS 操作步骤** 1. **使用 Raster Calculator** - 打开 `Raster Calculator`(Processing Toolbox 中搜索)。 - 输入条件表达式,例如将高程分为三类: ``` (dem@1 <= 500) * 1 + (dem@1 > 500 AND dem@1 <= 1000) * 2 + (dem@1 > 1000) * 3 ``` - 指定输出格式为 GeoTIFF。 2. **通过插件重分类(如 Reclassify by Table)** - 安装 `Reclassify by Table` 插件。 - 定义旧值范围与新值的映射表,例如: | 旧值范围 | 新值 | |----------|------| | 0-500 | 1 | | 500-1000 | 2 | | >1000 | 3 | 3. **GRASS GIS 工具** 在 Processing Toolbox 中搜索 `r.reclass`,上传规则文件(如 `rules.txt`)定义分类规则。 --- #### **常见问题与注意事项** - **数据范围不匹配**:检查 DEM 的元数据,确认高程值范围是否覆盖分类区间。 - **Nodata 处理**:在 QGIS 中可通过 `Raster Calculator` 添加条件 `ELSE 0` 或保留原值。 - **分类方法选择**: - 等间隔:适用于均匀分布的高程数据。 - 自然间断点:适合突出地形突变区域[^2]。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值