Транскрипт и код лупы

Я попытался портировать программу Javascript для лупы через Transcrypt в код Python. К сожалению, я не могу избавиться от рамки лупы, которая полностью перекрывает полное изображение. Оригинальный код был расположен здесь: https://www.w3schools.com/howto/tryit.asp?filename=tryhow_js_image_zoom

Код Python, который я сделал из этого:

class Magnifier():

    def __init__(self):
        self.img = document.getElementById("myimage")
        self.saved_src = self.img.src
        print(self.saved_src)
        self.resultat = document.getElementById("myresult");
        # create lens:
        self.lens = document.createElement("DIV");
        self.lens.setAttribute("class", "img-zoom-lens");
        # insert lens:
        self.img.parentElement.insertBefore(self.lens, self.img);
        # calculate the ratio between result DIV and lens:
        self.cx = self.resultat.offsetWidth / self.lens.offsetWidth;
        self.cy = self.resultat.offsetHeight / self.lens.offsetHeight;
        # set background properties for the result DIV:
        self.resultat.style.backgroundImage = "url('" + self.img.src + "')";
        self.resultat.style.backgroundSize = (self.img.width * self.cx) + "px " + (self.img.height * self.cy) + "px";
        # execute a function when someone moves the cursor over the image, or the lens:
        window.addEventListener("mousemove", self.moveLens);
        self.img.addEventListener("mousemove", self.moveLens);
        # and also for touch screens:
        self.lens.addEventListener("touchmove", self.moveLens);
        self.img.addEventListener("touchmove", self.moveLens);
        console.log("run")
        self.counter = 0

    def moveLens(self, e):
        # console.log("moveLens")
        self.img.src = self.saved_src + "?" + __new__(Date().getTime())
        if (not e): e = window.event # only for IE which has window.event
        a = self.img.getBoundingClientRect();
        # e.preventDefault()
        # get the cursor's x and y positions:
        # calculate the cursor's x and y coordinates, relative to the image:
        x = e.pageX - a.left;
        y = e.pageY - a.top;
        # print (a, e.pageX, e.pageY)
        # consider any page scrolling:
        x = x - window.pageXOffset;
        y = y - window.pageYOffset;
        # print (x, y)
        # calculate the position of the lens:
        # create lens:
        self.lens = document.createElement("DIV");
        self.lens.setAttribute("class", "img-zoom-lens");
        self.lens.setAttribute("position", "absolute")
        self.img.parentElement.insertBefore(self.lens, self.img)
        x = x - (self.lens.offsetWidth / 2);
        y = y - (self.lens.offsetHeight / 2);
        # prevent the lens from being positioned outside the image:
        if (x > self.img.width - self.lens.offsetWidth): x = self.img.width - self.lens.offsetWidth
        if (x < 0): x = 0;
        if (y > self.img.height - self.lens.offsetHeight): y = self.img.height - self.lens.offsetHeight;
        if (y < 0): y = 0;
        # set the position of the lens:
        print ("xy", x, y)
        self.lens.style.left = str(x) + "px";
        self.lens.style.top = str(y) + "px";
        # display what the lens "sees":
        self.resultat.style.backgroundPosition = "-" + str(x * self.cx) + "px -" + str(y * self.cy) + "px";

magnificent = Magnifier()

И это HTML для этого:

<html>
<head>
  <meta charset="utf-8" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <style>
  * {box-sizing: border-box;}
  .img-zoom-container {
    position: relative;
  }
  .img-zoom-lens {
    position: absolute;
    border: 1px solid #d4d4d4;
    /*set the size of the lens:*/
    width: 40px;
    height: 40px;
  }
  .img-zoom-result {
    border: 1px solid #d4d4d4;
    /*set the size of the result div:*/
    width: 300px;
    height: 300px;
  }
  </style>
</head>
<body>
<h1>Image Zoom</h1>
<p>Mouse over the image:</p>
<div class="img-zoom-container">
  <img id="myimage" src="https://raw.githubusercontent.com/bunkahle/Transcrypt-Examples/master/user-interface/computer-desktop.jpg" width="300" height="215">
  <div id="myresult" class="img-zoom-result"></div>
</div>
<p>The image must be placed inside a container with relative positioning.</p>
<p>The result can be put anywhere on the page, but must have the class name "img-zoom-result".</p>
<p>Make sure both the image and the result have IDs. These IDs are used when a javaScript initiates the zoom effect.</p>
<script src="__javascript__/magnifier.js" charset="UTF-8"></script>
</body>
</html>

Есть идеи, что может быть не так? Если закомментируйте строку:

self.img.parentElement.insertBefore(self.lens, self.img)

Я вообще не вижу рамки, и она работает как минимум на полпути. Но было бы неплохо иметь границу вокруг увеличенного пространства.

1 ответ

Вы создаете новые линзы снова и снова в вашем moveLens метод и назначить младшего из них self.lensперезаписывая ссылку на предыдущую (но не разрушая саму предыдущую линзу) в следующем коде:

    # create lens:
    self.lens = document.createElement("DIV");
    self.lens.setAttribute("class", "img-zoom-lens");
    self.lens.setAttribute("position", "absolute")
    self.img.parentElement.insertBefore(self.lens, self.img)

Вы перемещаете только последний созданный файл, остальные остаются видимыми и остаются в том месте, где они были созданы, поскольку self.lens.style.left = <position> только перемещает самый последний созданный.

Так что это просто вопрос удаления некоторого кода. Следующий код будет работать. Но это, вероятно, можно немного упростить.

class Magnifier():

    def __init__(self):
        self.img = document.getElementById("myimage")
        self.saved_src = self.img.src
        print(self.saved_src)
        self.resultat = document.getElementById("myresult");
        # create lens:
        self.lens = document.createElement("DIV");
        self.lens.setAttribute("class", "img-zoom-lens");
        self.lens.setAttribute("position", "absolute")
        # insert lens:
        self.img.parentElement.insertBefore(self.lens, self.img);
        # calculate the ratio between result DIV and lens:
        self.cx = self.resultat.offsetWidth / self.lens.offsetWidth;
        self.cy = self.resultat.offsetHeight / self.lens.offsetHeight;
        # set background properties for the result DIV:
        self.resultat.style.backgroundImage = "url('" + self.img.src + "')";
        self.resultat.style.backgroundSize = (self.img.width * self.cx) + "px " + (self.img.height * self.cy) + "px";
        # execute a function when someone moves the cursor over the image, or the lens:
        window.addEventListener("mousemove", self.moveLens);
        self.img.addEventListener("mousemove", self.moveLens);
        # and also for touch screens:
        self.lens.addEventListener("touchmove", self.moveLens);
        self.img.addEventListener("touchmove", self.moveLens);
        console.log("run")
        self.counter = 0

    def moveLens(self, e):
        # console.log("moveLens")
        self.img.src = self.saved_src + "?" + __new__(Date().getTime())
        if (not e): e = window.event # only for IE which has window.event
        a = self.img.getBoundingClientRect();
        # e.preventDefault()
        # get the cursor's x and y positions:
        # calculate the cursor's x and y coordinates, relative to the image:
        x = e.pageX - a.left;
        y = e.pageY - a.top;
        # print (a, e.pageX, e.pageY)
        # consider any page scrolling:
        x = x - window.pageXOffset;
        y = y - window.pageYOffset;
        # self.img.parentElement.insertBefore(self.lens, self.img)
        x = x - (self.lens.offsetWidth / 2);
        y = y - (self.lens.offsetHeight / 2);
        # prevent the lens from being positioned outside the image:
        if (x > self.img.width - self.lens.offsetWidth): x = self.img.width - self.lens.offsetWidth
        if (x < 0): x = 0;
        if (y > self.img.height - self.lens.offsetHeight): y = self.img.height - self.lens.offsetHeight;
        if (y < 0): y = 0;
        # set the position of the lens:
        print ("xy", x, y)
        self.lens.style.left = str(x) + "px";
        self.lens.style.top = str(y) + "px";
        # display what the lens "sees":
        self.resultat.style.backgroundPosition = "-" + str(x * self.cx) + "px -" + str(y * self.cy) + "px";

magnificent = Magnifier()
Другие вопросы по тегам