2017-05-09 58 views
2

我有一个类,它基本上绘制了一个16x30的网格。x,y在网格中的位置文本

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

OSD.setCursor(x y);

OSD.print('Text');

,并让它在x, y位置与定位在正确的位置的Text每个字符的字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) { 
 
    \t $(this).append(i) 
 
    \t i++; 
 
    \t //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

+1

我已经完全一样了这个问题。让我给你我答案的答案。 – CodeMonkey

+0

@Inuka谢谢! – fuzz

+0

@fuzz,如果你将光标放在任何数字上,它应该改变为文本的权利? –

回答

1

现在这个五月似乎不是理想的解决办法寻找,在这种情况下,我的道歉。我的要求是基于图像创建平铺网格,所以我设法做到这一点。

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

(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>

+1

嗯,那里有很多东西在里面。感谢您提供这个例子。不幸的是,我在函数之后能够根据放置光标的位置适当地定位文本:X,Y.我想我可以将它用于将来的事件功能,但是我真正定位的是定位并绘制文字。 – fuzz

+0

您是否找到了解决方案? – CodeMonkey

+0

不幸的是我没有。 – fuzz