From d9a0714de610b8a85ebe9d05c12d575f81bab691 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期三, 08 五月 2024 15:13:19 +0800
Subject: [PATCH] #

---
 src/components/area.jsx |   87 +++++--------------------------------------
 1 files changed, 11 insertions(+), 76 deletions(-)

diff --git a/src/components/area.jsx b/src/components/area.jsx
index 3505595..887d07e 100644
--- a/src/components/area.jsx
+++ b/src/components/area.jsx
@@ -1,89 +1,32 @@
 import React, { useRef, useState } from 'react';
 import { useFrame, useThree } from '@react-three/fiber';
 import * as THREE from 'three';
-import { CameraControls } from '@react-three/drei';
-import Text2 from './text';
-// import Annotation, { IAnnotationDataItem, IAnnotationRef } from './annotation';
+import Text from './text';
 
 const Y = 1;
-const Area = ({
-  x,
-  y,
-  width,
-  height,
-  areaNumber,
-  textHeight,
-  strokeColor,
-}) => {
+const Area = (props) => {
+  const { x, y, width, height, textContent, textHeight, strokeColor } = props;
   const [hovered, setHover] = useState(false);
-  const [clicked, setClicked] = useState(false);
   const meshRef = useRef(null);
-  const { controls } = useThree((state) => ({
-    controls: state.controls,
-  }));
 
-  // 杞崲涓簒杞村拰z杞寸粍鎴愮殑鍧愭爣绯讳腑鐨勪綅缃�
   const position = new THREE.Vector3(x + width / 2, Y, y + height / 2);
   const size = [width, 1, height];
-  textHeight ||= Y + 50;
+  // textHeight ||= Y + 50;
 
-  // 鐩告満绉诲姩鍒板尯鍩熺殑浣嶇疆
-  const handleClick = () => {
-    if (clicked) return;
-    setClicked(true);
-    // controls.fitToBox(meshRef.current!, true);
-    const mesh = meshRef.current;
-    const { x, y, z } = mesh.position;
-
-    const box = new THREE.Box3().setFromCenterAndSize(
-      new THREE.Vector3(x, (y + textHeight) / 2, z),
-      new THREE.Vector3(width, textHeight, height)
-    );
-    controls.fitToBox(box, true);
-
-    // annotationRef.current?.show();
-  };
-
-  // 鐩告満绉诲姩鍥炲師鏉ョ殑浣嶇疆
-  const handleDoubleClick = () => {
-    setClicked(false);
-  };
-
-  // 鐩戝惉榧犳爣绉诲叆鍜岀Щ鍑轰簨浠讹紝鏀瑰彉hover鐘舵��
-  const handlePointerOver = () => setHover(true);
-  const handlePointerOut = () => setHover(false);
-
-  // 姣忓抚鏇存柊杈规鐨勯鑹插拰绮楃粏
   useFrame(() => {
     const box = meshRef.current;
     if (box) {
-      const color = hovered || clicked ? strokeColor : 'white';
-      const thickness = clicked ? 0.5 : 0.2;
+      const color = !hovered ? strokeColor : 'white';
       const material = box.material;
       material.color.set(color);
-      material.linewidth = thickness;
+      material.linewidth = 0.2;
     }
   });
 
-  // const annotationRef = useRef(null);
-  const annotationData = [
-    {
-      label: '闀�',
-      value: width + '绫�',
-    },
-    {
-      label: '瀹�',
-      value: height + '绫�',
-    },
-  ];
-
   return (
     <group
-      onClick={handleClick}
-      onPointerOver={handlePointerOver}
-      onPointerOut={handlePointerOut}
-      onDoubleClick={handleDoubleClick}
-      onPointerMissed={() => setClicked(false)}
+      onPointerOver={() => setHover(true)}
+      onPointerOut={() => setHover(false)}
     >
       <mesh ref={meshRef} position={position}>
         <boxGeometry attach="geometry" args={size} />
@@ -94,20 +37,12 @@
         <meshBasicMaterial attach="material" color={strokeColor} transparent opacity={0.2} />
       </mesh>
 
-      {areaNumber && (
-        <Text2
+      {textContent && (
+        <Text
           position={new THREE.Vector3(position.x, textHeight, position.z)}
-          text={areaNumber}
-          scale={new THREE.Vector3(100, 100, 100)}
-          fontSize={100}
+          text={textContent}
         />
       )}
-      {/* <Annotation
-        ref={annotationRef}
-        title={areaNumber}
-        position={position}
-        data={annotationData}
-      ></Annotation> */}
     </group>
   );
 };

--
Gitblit v1.9.1