当前位置: 首页 > news >正文

做去自己的网站首页百度店铺怎么开通

做去自己的网站首页,百度店铺怎么开通,东莞网络科技有限公司简介,西安建设网站电话号码效果: 拖拽和缩放(缩放以鼠标为中心) 代码具体实现如下: 但是有几个注意点 (1)为什么需要设置 transform-origin: 0 0; 缩放时以鼠标为中心进行缩放。这意味着需要手动计算缩放过程中元素的位移&#…

效果:

拖拽和缩放(缩放以鼠标为中心)

代码具体实现如下:

但是有几个注意点

(1)为什么需要设置 transform-origin: 0 0;

缩放时以鼠标为中心进行缩放。这意味着需要手动计算缩放过程中元素的位移,以确保缩放是以鼠标为中心的。如果不设置 transform-origin,缩放和位移的计算将变得更加复杂。

设置 transform-origin: 0 0; 后,所有的位移和缩放都是基于左上角进行的,这使得计算变换的位移量更加直观和简单。只需要考虑从左上角开始的平移和缩放,而不需要考虑元素的中心点。

如果不设置 transform-origin: 0 0;,在缩放和位移时需要考虑变换原点的位置,这会增加计算的复杂性。

(2)关于代码中的(scale / prevScale - 1)

在缩放过程中需要计算新的平移值,使得缩放以鼠标为中心。(scale / prevScale - 1) 计算出相对于原始缩放比例的变化量。

例如,如果 scale 增加了10%,那么 scale / prevScale 会是1.1,减去1后得到0.1,表示增加的10%。

offsetX * (scale / prevScale - 1) 计算出由于缩放而导致的水平偏移量。类似地,offsetY * (scale / prevScale - 1) 计算出由于缩放而导致的垂直偏移量。

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>移动和缩放容器</title><style>body {margin: 0;height: 100vh;display: flex;justify-content: center;align-items: center;background-color: #f0f0f0;overflow: hidden;}#container {width: 200px;height: 200px;background-color: #4caf50;cursor: grab;user-select: none;transform-origin: 0 0; /* 设置原点为左上角 */}</style></head><body><div id="container">ABC</div><script>const container = document.getElementById("container");let isDragging = false;let startX, startY, initialX, initialY;let scale = 1;let translateX = 0,translateY = 0;container.addEventListener("mousedown", (e) => {isDragging = true;startX = e.clientX;startY = e.clientY;initialX = translateX;initialY = translateY;container.style.cursor = "grabbing";});document.addEventListener("mousemove", (e) => {if (isDragging) {const dx = e.clientX - startX;const dy = e.clientY - startY;translateX = initialX + dx;translateY = initialY + dy;container.style.transform = `translate(${translateX}px, ${translateY}px) scale(${scale})`;}});document.addEventListener("mouseup", () => {isDragging = false;container.style.cursor = "grab";});container.addEventListener("wheel", (e) => {e.preventDefault();const minScale = 0.5;const maxScale = 3;const rect = container.getBoundingClientRect();const offsetX = e.clientX - rect.left;const offsetY = e.clientY - rect.top;const prevScale = scale;const delta = e.deltaY || e.detail || e.wheelDelta;// console.log(delta, "delta");scale += delta * -0.01;scale = Math.min(Math.max(minScale, scale), maxScale);const newX = offsetX * (scale / prevScale - 1);const newY = offsetY * (scale / prevScale - 1);console.log(newX);translateX -= newX;translateY -= newY;container.style.transform = `translate(${translateX}px, ${translateY}px) scale(${scale})`;});</script></body>
</html>
http://www.fp688.cn/news/153236.html

相关文章:

  • wordpress改浏览数数据库长沙快速排名优化
  • 什么公司会招网站建设如何做企业网站
  • 设计签名免费艺术签名青岛seo网站排名优化
  • 乌兰察布做网站的公司30个免费货源网站
  • 南京门户网站建设永久免费个人网站注册
  • 外国ps素材网站软件推广方案经典范文
  • 网站项目如何做需求分析品牌推广工作内容
  • 做网站与做app哪个容易精准客源引流平台
  • 网络服务提供者知道网络用户利用其网络服务侵害志鸿优化网
  • 飞鸽crm电销系统seo费用
  • 邗江区疫情最新消息seo优化排名推广
  • 美国做企业用什么网站南宁网站seo大概多少钱
  • 科技有限公司网站搜索引擎优化论文3000字
  • 做网站需要什么人员网络整合营销是什么意思
  • b2c网站综合对比评价河源seo
  • 网站信息备案查询推销产品怎么推广
  • 商昊网站建设中国十大营销策划公司排名
  • 大港网站建设互联网舆情
  • 动漫制作专业的初始岗位广东seo点击排名软件哪家好
  • 医药网站前置审批百度推广关键词排名在哪看
  • 营销型企业网站建设的基本原则是南阳seo
  • 聊城做网站推广哪家好全国新闻媒体发稿平台
  • 产品网站免费模板百度网站链接
  • 网站建设没有预付款竞价推广怎样管理
  • 网站开发设计方案营销策划方案模板范文
  • 展示型网站一样做seo优化站长素材网
  • 电子产品东莞网站建设汉中网络推广
  • 企业宣传及介绍pptseo外包公司兴田德润
  • wordpress 添加备案信息四川网络推广seo
  • 企业网站流量太原seo快速排名怎么样