2012-01-04 4 views
5

Prima di implementare il nostro, esiste una parte di codice Java Open Source esistente che prende una stringa di scacchi FEN e la converte in una rappresentazione HTML della scacchiera?FEN (notazione degli scacchi) al generatore HTML? Open source Java

codice

Un FEN assomiglia a questo: rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR w KQkq - 0 1

L'uscita sarebbe qualcosa di simile <table><tr><td>♘</td><td>♛</td><td>...

Una soluzione icone-based, o anche una soluzione che produce una grande immagine invece di HTML, potrebbe essere accettabile troppo . È per l'integrazione in un'app Android.

(Here is an implementation in Python)

+1

Perché immagini? I simboli di scacchi non sono parte di Unicode? –

+0

@KerrekSB: Infatti! Anche quello andrebbe bene. Aggiornamento della mia domanda. –

+0

Hm, sembra esserci un buon pacchetto LaTeX ("skak"), e c'è sempre LaTeX2HTML, ma sembra uno spreco. Una soluzione direct-to-HTML sarebbe bella. –

risposta

5

ho trovato un po 'di CSS3 utile da questo luogo: http://designindevelopment.com/css/css3-chess-board/
Così mi è venuta con il seguente:

<html> 
<head> 
    <style type="text/css"> 
     .chess_board { border:1px solid #333; } 
     .chess_board td { 
      background:#fff; background:-moz-linear-gradient(top, #fff, #eee); 
      background:-webkit-gradient(linear,0 0, 0 100%, from(#fff), to(#eee)); 
      box-shadow:inset 0 0 0 1px #fff; 
      -moz-box-shadow:inset 0 0 0 1px #fff; 
      -webkit-box-shadow:inset 0 0 0 1px #fff; 
      height:40px; text-align:center; vertical-align:middle; width:40px; font-size:30px;} 
     .chess_board tr:nth-child(odd) td:nth-child(even), 
     .chess_board tr:nth-child(even) td:nth-child(odd) { 
      background:#ccc; background:-moz-linear-gradient(top, #ccc, #eee); 
      background:-webkit-gradient(linear,0 0, 0 100%, from(#ccc), to(#eee)); 
      box-shadow:inset 0 0 10px rgba(0,0,0,.4); 
      -moz-box-shadow:inset 0 0 10px rgba(0,0,0,.4); 
      -webkit-box-shadow:inset 0 0 10px rgba(0,0,0,.4); } 
    </style> 
    <script type="text/javascript"> 
     function renderFen(fentxt) { 
      fentxt = fentxt.replace(/ .*/g, ''); 
      fentxt = fentxt.replace(/r/g, 'x'); // Convert black rooks to 'x' to avoid mixup with <tr></tr> tags 
      fentxt = fentxt.replace(/\//g, '</tr><tr>'); 
      fentxt = fentxt.replace(/1/g, '<td></td>'); 
      fentxt = fentxt.replace(/2/g, '<td></td><td></td>'); 
      fentxt = fentxt.replace(/3/g, '<td></td><td></td><td></td>'); 
      fentxt = fentxt.replace(/4/g, '<td></td><td></td><td></td><td></td>'); 
      fentxt = fentxt.replace(/5/g, '<td></td><td></td><td></td><td></td><td></td>'); 
      fentxt = fentxt.replace(/6/g, '<td></td><td></td><td></td><td></td><td></td><td></td>'); 
      fentxt = fentxt.replace(/7/g, '<td></td><td></td><td></td><td></td><td></td><td></td><td></td>'); 
      fentxt = fentxt.replace(/8/g, '<td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td>'); 
      fentxt = fentxt.replace(/K/g, '<td>&#9812;</td>'); 
      fentxt = fentxt.replace(/Q/g, '<td>&#9813;</td>'); 
      fentxt = fentxt.replace(/R/g, '<td>&#9814;</td>'); 
      fentxt = fentxt.replace(/B/g, '<td>&#9815;</td>'); 
      fentxt = fentxt.replace(/N/g, '<td>&#9816;</td>'); 
      fentxt = fentxt.replace(/P/g, '<td>&#9817;</td>'); 
      fentxt = fentxt.replace(/k/g, '<td>&#9818;</td>'); 
      fentxt = fentxt.replace(/q/g, '<td>&#9819;</td>'); 
      fentxt = fentxt.replace(/x/g, '<td>&#9820;</td>'); 
      fentxt = fentxt.replace(/b/g, '<td>&#9821;</td>'); 
      fentxt = fentxt.replace(/n/g, '<td>&#9822;</td>'); 
      fentxt = fentxt.replace(/p/g, '<td>&#9823;</td>'); 
      return '<table class="chess_board" cellspacing="0" cellpadding="0"><tr>' + fentxt + '</tr></table>'; 
     } 
    </script> 
</head> 
<body> 
    <script type="text/javascript"> 
     document.write(renderFen('rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR w KQkq - 0 1')); 
    </script> 
</body> 

1

Citando Alexander Maryanovsky Jin site sito:

Chi Jin

Jin è un open source, cross platform, client grafico per scacchi server, scritto in Java . Jin può funzionare come applicazione standalone (disponibile su questo sito Web) o come applet direttamente dal browser (disponibile sul sito Web del server di scacchi).

Il suo progetto è open source e disponibile su Sourceforge.

Afferra la classe Position.java e troverai un pezzo di codice FEN per la gestione del codice Java.

+0

+1 Ho già accettato una risposta, ma il fatto che Jin sia in Java rende una risposta più ravvicinata alla mia domanda scritta (anche se nel mio caso d'uso particolare, JavaScript è in effetti anche bello) –