Я работаю в React. Я работаю над перетаскиванием подразделения, скажем Q, и переносом его в другое подразделение, скажем A. Контейнер A имеет свойство увеличения и уменьшения, которое реализовано с помощью функции масштабирования. Когда Q сбрасывается на A, Q становится частью A, а при отбрасывании на A, масштаб Q относительно A. Теперь при перетаскивании Q из A, Q возвращается к своему первоначальному размеру, а не с курсором. Как сделать размер компонента при перетаскивании из A относительно шкалы A. Ниже приведен код, который будет полезен для справки
zoomState(e) {
switch (e.deltaY > 0) {
case true:
if(out==0)
{
if(this.state.scale>2.5)
{
this.zoomOut(e);
}
}
else{
}
break;
default:
this.zoomIn(e);
}
}
zoomIn = (e) => {
this.setState({ scale: this.state.scale * 2});
console.log("zoomin" + ""+ this.state.scale)
e.target.style.transform = `scale(${this.state.scale})`
out=0
}
zoomOut = (e) => {
this.setState({ scale: this.state.scale / 2});
e.target.style.transform = `scale(${this.state.scale})`
console.log("zoomout" + ""+ this.state.scale)
if(this.state.scale==1)
{
e.target.style.transform=null
}
}
dragStart(event) {
event.dataTransfer.setData("Text", event.target.id);
var dragtarget1=document.getElementById("dragtarget1")
var dragtarget2=document.getElementById("dragtarget2")
if(event.target.id=="dragtarget1")
{
setTimeout(function(){
dragtarget1.classList.add('hide');
});
}
if(event.target.id=="dragtarget2")
{
setTimeout(function(){
dragtarget2.classList.add('hide');
});
}
}
allowDrop(event) {
event.preventDefault();
}
drop=(event)=> {
event.preventDefault();
var data = document.getElementById(event.dataTransfer.getData("Text"));
event.target.appendChild(data);
data.style.position = "fixed";
if(this.state.scale>1){
data.style.left = (event.nativeEvent.offsetX - data.clientWidth / 2) + "px";
data.style.top = (event.nativeEvent.offsetY - data.clientHeight / 2) + "px";
}
else{
data.style.left = (event.clientX - data.clientWidth / 2) + "px";
data.style.top = (event.clientY - data.clientHeight / 2) + "px";
}
var dragtarget1=document.getElementById("dragtarget1")
setTimeout(function(){
dragtarget1.classList.remove('hide');
});
var dragtarget2=document.getElementById("dragtarget2")
setTimeout(function(){
dragtarget2.classList.remove('hide');
});
}
cood(){
var bg=document.getElementById("bg")
bg.style.transform=null
}
onMouseMove(e)
{
xcood=e.nativeEvent.offsetX
ycood= e.nativeEvent.offsetY
console.log(xcood,ycood)
}
render() {
return (
<div id="base" >
<div className="first" id="first">
</div>
<div className="second">
<div className="container">
<div id="bg" ref="bg"
onWheel={(e)=>this.zoomState(e)}
className="bg-image-wrapper"
style={{ 'transform': `scale(${this.state.scale})`}}
onDrop={(e)=>this.drop(e)} onDragOver={(e)=>this.allowDrop(e)}
onDoubleClick={
e => {
this.handleDoubleClick (e);
}}
>
</div>
</div>
<div className="comp">
<div className="droptarget1">
<div
style={{
height:25,
width:25,
backgroundColor:"red",
position:"fixed",
//transform:`scale(${this.state.scale})`
transform:`scale(${this.state.scale2})`
}}
onDragStart={(e)=>this.dragStart(e)} draggable="true" id="dragtarget1">
</div>
</div>
<div className="droptarget2">
<div
style={{
height:25,
width:25,
backgroundColor:"blue",
position:"fixed",
}}
onDragStart={(e)=>this.dragStart(e)} draggable="true" id="dragtarget2">
</div>
</div>
</div>
</div>
<div className="third">
</div>
</div>
);
}