javascript - 将文本定位在网格中的 x、y 位置

标签 javascript

我有一个类,基本上是绘制一个 16x30 的网格。

理想情况下,我希望能够执行:

OSD.setCursor(x y);

OSD.print('Text');

并将单词 Text 定位在 x, y 位置,Text 的每个字符都定位在网格中的正确位置。

这是我目前所拥有的:

class MAX7456 {
  constructor() {
    this.items = null;
    this.divs = null;
  }

  begin() {
    var ratioH = 16,
        ratioW = 30;
    
    var parent = $('<div />', {
        class: 'grid', 
        width: ratioW  * 25,
        height: ratioH  * 18
    }).addClass('grid').appendTo('body');

    for (var i = 0; i < ratioH; i++) {
        for(var p = 0; p < ratioW; p++) {
            this.divs = $('<div />', {
                width: 25 - 1, 
                height: 18 - 1
            }).appendTo(parent);
            
            this.items = $('<span />', {
                width: 25 - 1, 
                height: 18 - 1,
                style: "padding-left: 2px;"
            }).appendTo(this.divs);
        }
    }
  }

  setCursor(x, y) {
    $('div > span:nth-child(2n-1)').text(function (i, txt) {
    	$(this).append(i)
    	i++;
    	//console.log(txt + $(this).next().text());
    });
  }
  print (txt) {
  } 
}

var OSD = new MAX7456();
OSD.begin(); // create grid
OSD.setCursor(0, 0); // set text at cursor (x, y)
OSD.print("Label 2");
body {
    padding: 0;
    font-size: 12px;
}

.grid {
    border: 1px solid #ccc;
    border-width: 1px 0 0 1px;
}

.grid div {
    border: 1px solid #ccc;
    border-width: 0 1px 1px 0;
    float: left;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

JSFiddle

最佳答案

现在这似乎不是理想的解决方案,在那种情况下我很抱歉。我的要求是创建一个基于图像的平铺网格,所以这就是我设法做到的。

  • 总图 block 数可以根据需要变化。 (我的案例 2500 block 瓷砖)
  • 当您调整图像大小时,将决定图 block 的大小。

(function($) {
  var imagePadding = 0;
  var pluginName = "tiles",
    defaults = {
      x: 2, // tiles in x axis
      y: 2, // tiles in y axis
      gap: {
        x: 1,
        y: 1
      }
    };

  function Plugin(elem, options) {

    options = $.extend({}, defaults, options);

    var $elem = $(elem).wrap("<div class='tiles-wrapper' />"),
      width = $elem.outerWidth(),
      height = $elem.outerHeight(),
      n_tiles = options.x * options.y,
      tiles = [];

    $elem.parent(".tiles-wrapper").css({
      position: "relative",
      width: width,
      height: height
    });

    for (var $i = 0; $i < n_tiles; $i++) {
      if ($i >= imagePadding) {
        tiles.push("<div class='tile' data-id='" + $i + "' data-clipboard-text='" + $i + "'>" + $i + "</div>");
      } else {
        tiles.push("<div class='tile' data-id='" + $i + "' data-clipboard-text='" + $i + "'></div>");
      }
    }

    var $tiles = $(tiles.join(""));

    // Hide original image and insert tiles in DOM
    $elem.hide().after($tiles);

    // Set backgrounds
    $tiles.css({
      float: "left",
      width: (width / options.x) - (options.gap.x || options.gap),
      height: (height / options.y) - (options.gap.y || options.gap),
      marginRight: options.gap.x || options.gap,
      marginBottom: options.gap.y || options.gap,
      backgroundImage: "url(" + $elem[0].src + ")",
      lineHeight: (height / options.y) - (options.gap.y || options.gap) + "px",
      textAlign: "center"
    });

    // Adjust position
    $tiles.each(function() {
      var pos = $(this).position();
      this.style.backgroundPosition = -pos.left + "px " + -pos.top + "px";
    });

  }

  $.fn[pluginName] = function(options) {
    return this.each(function() {
      new Plugin(this, options);
    });
  };

}(jQuery));

window.onload = function() {
  $('#img').tiles({
    x: 21.909,
    y: 21.909
  });

  $(".tile").click(function() {
    console.log($(this).data("id"));
  });

};
.tiles-wrapper {
  z-index: 999;
}

.tile:hover {
  opacity: .80;
  filter: alpha(opacity=80);
  background: #fecd1f!important;
}
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script type="text/javascript" src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
<!-- Latest compiled and minified JavaScript -->
<script type="text/javascript" src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>

<div class="container">
  <div class="row">
    <div class="col-md-8">
      <div class="banner-head"></div>
      <div class="row">
        <div class="col-md-12">
          <div class="image-holder">
            <img id="img" src=""
              alt="event picture" />
          </div>
        </div>
      </div>
    </div>
  </div>
</div>

关于javascript - 将文本定位在网格中的 x、y 位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43860427/

相关文章:

javascript - 选项 Prop 更改默认选定值 - Jquery

javascript - 未正确检索重音字符

javascript - 我可以在 ES2020 之前使用这个 Promise.allSettled 的实现吗?

javascript - 如何从 Angular 日期选择器中禁用分钟和文本(东部标准时间)?

javascript - 如何将下拉列表值作为参数传递给函数

javascript - Jquery 循环问题

javascript - app.js 中需要错误

javascript - 解决 promise 是一个异步过程吗?

javascript - 一旦 div 滚动到尽头,页面就会滚动

javascript - 下拉悬停 CSS