テキストをスロットのようにグルグルと回転させて表示するコード(プラグイン)

  PR
  
  
  
 
 
 Text Slot Machine
スロットのロールに文字を入れて
それを回転させて、指定した文字が表示冴えれるようにしたものです
初期設定があるので、その部分を変更することで簡単に目的の文字や、他の表示される文字を決めることが出来ます
javascriptのsettingのところを調整すれば、文字の大きさとか色々調整が出来ます
(使えるのは英字の大文字だけのようです)
コード
HTML
<canvas></canvas>
CSS
canvas{
  position: absolute;
  background: #111;
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
}
javascript
/* -------------------------------------- */
/* ------------  Settings  -------------- */
/* -------------------------------------- */
text = 'HELLO';  // The message displayed
chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';  // All possible Charactrers
scale = 60;  // Font size and overall scale
breaks = 0.003;  // Speed loss per frame
endSpeed = 0.05;  // Speed at which the letter stopps
firstLetter = 220;  // Number of frames untill the first letter stopps (60 frames per second)
delay = 40;  // Number of frames between letters stopping
canvas = document.querySelector('canvas');
ctx = canvas.getContext('2d');
text = text.split('');
chars = chars.split('');
charMap = [];
offset = [];
offsetV = [];
for(var i=0;i<chars.length;i++){
  charMap[chars[i]] = i;
}
for(var i=0;i<text.length;i++){
  var f = firstLetter+delay*i;
  offsetV[i] = endSpeed+breaks*f;
  offset[i] = -(1+f)*(breaks*f+2*endSpeed)/2;
}
(onresize = function(){
  canvas.width = canvas.clientWidth;
  canvas.height = canvas.clientHeight;
})();
requestAnimationFrame(loop = function(){
  ctx.setTransform(1,0,0,1,0,0);
  ctx.clearRect(0,0,canvas.width,canvas.height);
  ctx.globalAlpha = 1;
  ctx.fillStyle = '#622';
  ctx.fillRect(0,(canvas.height-scale)/2,canvas.width,scale);
  for(var i=0;i<text.length;i++){
    ctx.fillStyle = '#ccc';
    ctx.textBaseline = 'middle';
    ctx.textAlign = 'center';
    ctx.setTransform(1,0,0,1,Math.floor((canvas.width-scale*(text.length-1))/2),Math.floor(canvas.height/2));
    var o = offset[i];
    while(o<0)o++;
    o %= 1;
    var h = Math.ceil(canvas.height/2/scale)
    for(var j=-h;j<h;j++){
      var c = charMap[text[i]]+j-Math.floor(offset[i]);
      while(c<0)c+=chars.length;
      c %= chars.length;
      var s = 1-Math.abs(j+o)/(canvas.height/2/scale+1)
      ctx.globalAlpha = s
      ctx.font = scale*s + 'px Helvetica'
      ctx.fillText(chars[c],scale*i,(j+o)*scale);
    }
    offset[i] += offsetV[i];
    offsetV[i] -= breaks;
    if(offsetV[i]<endSpeed){
      offset[i] = 0;
      offsetV[i] = 0;
    }
  }
  
  requestAnimationFrame(loop);
});
コードをファイルでダウンロードする
DOWNLOAD
  PR
  
  
  
 
 




 
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
   

COMMENT