gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 23:46:25 26 4
gpt4 key购买 nike

我有一个类,基本上是绘制一个 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com