【问题标题】:Connecting images with lines用线条连接图像
【发布时间】:2017-07-28 07:19:08
【问题描述】:

我试图用线条测验匹配两对。我在左边有几张图片,在右边有几张图片,当你点击这对图片时,我需要用线条将它连接起来。它应该适用于任何组合,所以如果我单击左侧的图像 1 和右侧的图像 3,它们应该与线连接。然后,如果我再次单击右侧的图像 1 和左侧的图像 2,则应删除前一行,并且需要在这两个图像之间制作新的一行。 html sn-p:

function lineDistance(x, y, x0, y0){
    return Math.sqrt((x -= x0) * x + (y -= y0) * y);
};

function drawLine(a, b, line) {
  var pointA = $(a ).offset();
  var pointB = $(b).offset();
  var pointAcenterX = $(a).width() / 2;
  var pointAcenterY = $(a).height() / 2;
  var pointBcenterX = $(b).width() / 2;
  var pointBcenterY = $(b).height() / 2;
  var angle = Math.atan2(pointB.top - pointA.top, pointB.left - pointA.left) * 180 / Math.PI;
  var distance = lineDistance(pointA.left, pointA.top, pointB.left, pointB.top);

 // Set Angle
  $(line).css('transform', 'rotate(' + angle + 'deg)');


  // Set Width
  $(line).css('width', distance + 'px');
                  
  // Set Position
  $(line).css('position', 'absolute');
  if(pointB.left < pointA.left) {
    $(line).offset({top: pointA.top + pointAcenterY, left: pointB.left + pointBcenterX});
  } else {
    $(line).offset({top: pointA.top + pointAcenterY, left: pointA.left + pointAcenterX});
  }
}
new drawLine('.a', '.b', '.line');
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="question">
  <div id="old" class="left_side one_half svg left">
    <a href="#" data-number="1"><img class="a" src="assets/svg/Kerze.svg"></a>
    <a href="#" data-number="2"><img src="assets/svg/Telefon.svg"></a>
    <a href="#" data-number="3"><img src="assets/svg/Schreibmaschine.svg"></a>
    <a href="#" data-number="4"><img src="assets/svg/TV_old.svg"></a>
    <a href="#" data-number="5"><img src="assets/svg/Zeitstopper.svg"></a>
    <a href="#" data-number="6"><img src="assets/svg/Besen.svg"></a>
    <a href="#" data-number="7"><img src="assets/svg/Waschen.svg"></a>
  </div>
  <div class="left_side one_half svg right">
    <a href="#" data-letter="NS"><img src="assets/svg/Iwatch.svg"></a>
    <a href="#" data-letter="RT"><img src="assets/svg/Laptop.svg"></a>
    <a href="#" data-letter="TE"><img src="assets/svg/Staubsauger.svg"></a>
    <a href="#" data-letter="IN"><img src="assets/svg/Waschmaschine.svg"></a>
    <a href="#" data-letter="EI"><img src="assets/svg/TV_new.svg"></a>
    <a href="#" data-letter="AL"><img src="assets/svg/Gluehbirne.svg"></a>
    <a href="#" data-letter="BE"><img class="b" src="assets/svg/Iphone.svg"></a>
    <div class="line"></div>  
  </div>
</div>

我设法在两个图像之间划出一条线(从 a 类到 b 类),并且它总是被计算为正好在直角上,但我不能让它看起来像我上面描述的那样工作。有任何想法吗?谢谢。

【问题讨论】:

    标签: javascript jquery html css image


    【解决方案1】:
    var setLeft = false, setRight = false;
    $('.leftSide img').click(function(){
        $('.leftSide img').removeClass('a');
        $(this).addClass('a');
      setLeft = true;
      new drawLine('.a', '.b', '.line');
    });
    $('.rightSide img').click(function(){
        $('.rightSide img').removeClass('b');
        $(this).addClass('b');
      setRight = true;
      new drawLine('.a', '.b', '.line');
    });
    

    您可以使用标志变量,当从右侧单击图像时,将右侧标志变量设置为 true,并对其他变量执行相同操作。

    然后在你的函数drawLine 中检查两个标志是否为真,然后在ab 之间画线并将两个标志变量设置为false

    function lineDistance(x, y, x0, y0){
        return Math.sqrt((x -= x0) * x + (y -= y0) * y);
    };
    
    function drawLine(a, b, line) {
    
    	if(setLeft && setRight){
      	setLeft = false;
        setRight = false;
        var pointA = $(a).offset();
        var pointB = $(b).offset();
        console.log(pointA);
        console.log(pointB);
        var pointAcenterX = $(a).width() / 2;
        var pointAcenterY = $(a).height() / 2;
        var pointBcenterX = $(b).width() / 2;
        var pointBcenterY = $(b).height() / 2;
        var angle = Math.atan2(pointB.top - pointA.top, pointB.left - pointA.left) * 180 / Math.PI;
        var distance = lineDistance(pointA.left, pointA.top, pointB.left, pointB.top);
    
       // Set Angle
        $(line).css('transform', 'rotate(' + angle + 'deg)');
    
    
        // Set Width
        $(line).css('width', distance + 'px');
    
        // Set Position
        $(line).css('position', 'absolute');
        if(pointB.left < pointA.left) {
          $(line).offset({top: pointA.top + pointAcenterY, left: pointB.left + pointBcenterX});
        } else {
          $(line).offset({top: pointA.top + pointAcenterY, left: pointA.left + pointAcenterX});
        }
      }
    }
    //new drawLine('.a', '.b', '.line');
    var setLeft = false, setRight = false;
    $('.leftSide img').click(function(){
    	$('.leftSide img').removeClass('a');
    	$(this).addClass('a');
      setLeft = true;
      new drawLine('.a', '.b', '.line');
    });
    $('.rightSide img').click(function(){
    	$('.rightSide img').removeClass('b');
    	$(this).addClass('b');
      setRight = true;
      new drawLine('.a', '.b', '.line');
    });
    .left{
      float:left;
    }
    .right{
      float:right;
    }
    .one_half{
      width:40%;
    }
    img{
      max-width:100%;
    }
    .line{
      background: red;
      height:1px;
    }
    .question{
      position: relative;
      overflow: hidden;
    }
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <div class="question">
      <div id="old" class="left_side one_half svg left leftSide">
        <a href="#" data-number="1"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
        <a href="#" data-number="2"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
        <a href="#" data-number="3"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
        <a href="#" data-number="4"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
        <a href="#" data-number="5"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
        <a href="#" data-number="6"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
        <a href="#" data-number="7"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
      </div>
      <div class="left_side one_half svg right rightSide">
        <a href="#" data-letter="NS"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
        <a href="#" data-letter="RT"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
        <a href="#" data-letter="TE"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
        <a href="#" data-letter="IN"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
        <a href="#" data-letter="EI"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
        <a href="#" data-letter="AL"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
        <a href="#" data-letter="BE"><img src="https://www.w3schools.com/css/trolltunga.jpg"></a>
        <div class="line"></div>  
      </div>
    </div>

    【讨论】:

    • 感谢您的回答。这是一个好的开始,只是存在一个问题,即一行只显示一对,当我点击另一对 og 图像时,前一行消失了,而且,它当您单击左侧图像下方的右侧图像时效果很好,当我尝试将左侧图像上方的右侧图像配对时,线路连接不正确。