Js实现任意位置缩放图片,深入理解背后原理

warning: 这篇文章距离上次修改已过200天,其中的内容可能已经有所变动。

在JavaScript中实现任意位置缩放图片,通常涉及到事件监听和计算。以下是一个简单的实现示例:

HTML部分:




<img id="image" src="path/to/your/image.jpg" alt="Resizable Image" />
<div id="handles">
  <div class="handle e">e</div>
  <div class="handle s">s</div>
  <div class="handle w">w</div>
  <div class="handle n">n</div>
  <div class="handle ne">ne</div>
  <div class="handle se">se</div>
  <div class="handle sw">sw</div>
  <div class="handle nw">nw</div>
</div>

CSS部分:




#image {
  position: absolute;
  cursor: move;
}
#handles {
  position: absolute;
  z-index: 10;
}
.handle {
  position: absolute;
  width: 10px;
  height: 10px;
  background: #ccc;
  font-size: 12px;
  color: #fff;
  line-height: 10px;
  text-align: center;
  cursor: nwse-resize;
  z-index: 100;
}
/* Define the positions of the resize handles */
.handle.e { top: 0; right: 0; }
.handle.s { bottom: 0; right: 0; }
.handle.w { top: 0; left: 0; }
.handle.n { top: 0; left: 0; }
.handle.ne { top: 0; right: 0; }
.handle.se { bottom: 0; right: 0; }
.handle.sw { bottom: 0; left: 0; }
.handle.nw { top: 0; left: 0; }

JavaScript部分:




const image = document.getElementById('image');
const handles = document.querySelectorAll('#handles .handle');
let isResizing = false;
let startX, startY, startWidth, startHeight;
 
handles.forEach(handle => {
  handle.addEventListener('mousedown', function(e) {
    e.preventDefault();
    isResizing = true;
 
    startX = e.clientX;
    startY = e.clientY;
    startWidth = parseInt(image.width, 10);
    startHeight = parseInt(image.height, 10);
 
    document.addEventListener('mousemove', resize);
    document.addEventListener('mouseup', stopResize);
  });
});
 
function resize(e) {
  if (isResizing) {
    const deltaX = e.clientX - startX;
    const deltaY = e.clientY - startY;
 
    // Resize according to the handle position
    switch (this.className) {
      case 'handle e':
        image.width = startWidth + deltaX;
        break;
      case 'handle s':
        image.height = startHeight + deltaY;
        break;
      case 'handle w':
        image.width = startWidth - deltaX;
        image.style.left = s
最后修改于:2024年08月12日 16:17

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日