sauvegarder les mots intéressants du dico pour pas tout relire
This commit is contained in:
parent
b5930083bb
commit
97daba979f
51
Grille.php
51
Grille.php
@ -45,8 +45,6 @@ class Grille implements ArrayAccess
|
|||||||
$this->positions[] = [$x, $y];
|
$this->positions[] = [$x, $y];
|
||||||
}
|
}
|
||||||
$this->nb_positions = count($this->positions);
|
$this->nb_positions = count($this->positions);
|
||||||
|
|
||||||
$this->dico = mots_espaces(max($hauteur, $largeur));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function get_ligne($y, $largeur)
|
public function get_ligne($y, $largeur)
|
||||||
@ -65,6 +63,23 @@ class Grille implements ArrayAccess
|
|||||||
return $colonne;
|
return $colonne;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function genere($id)
|
||||||
|
{
|
||||||
|
mt_srand(crc32($id));
|
||||||
|
|
||||||
|
$this->dico = mots_espaces(max($this->hauteur, $this->largeur));
|
||||||
|
|
||||||
|
$grilles = $this->gen_grilles();
|
||||||
|
$grilles->current();
|
||||||
|
|
||||||
|
if ($grilles->valid()) {
|
||||||
|
$this->save($id);
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public function gen_grilles($i = 0, $lettres_ligne = NULL)
|
public function gen_grilles($i = 0, $lettres_ligne = NULL)
|
||||||
{
|
{
|
||||||
[$x, $y] = $this->positions[$i];
|
[$x, $y] = $this->positions[$i];
|
||||||
@ -137,21 +152,6 @@ class Grille implements ArrayAccess
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function genere($id)
|
|
||||||
{
|
|
||||||
mt_srand(crc32($id));
|
|
||||||
|
|
||||||
$grilles = $this->gen_grilles();
|
|
||||||
$grilles->current();
|
|
||||||
|
|
||||||
if ($grilles->valid()) {
|
|
||||||
$this->save($id);
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function hash()
|
public function hash()
|
||||||
{
|
{
|
||||||
$string = "";
|
$string = "";
|
||||||
@ -182,6 +182,21 @@ class Grille implements ArrayAccess
|
|||||||
session_start(["use_cookies" => false]);
|
session_start(["use_cookies" => false]);
|
||||||
|
|
||||||
$_SESSION["grille"] = (string)$this;
|
$_SESSION["grille"] = (string)$this;
|
||||||
|
$_SESSION["dico"] = [];
|
||||||
|
foreach ($this->lignes as $y => $mots) {
|
||||||
|
foreach($mots as $mot) {
|
||||||
|
$longueur = strlen($mot);
|
||||||
|
if (!isset($_SESSION["dico"][$longueur])) $_SESSION["dico"][$longueur] = [];
|
||||||
|
$_SESSION["dico"][$longueur][$mot] = $this->dico[$longueur][$mot];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
foreach ($this->colonnes as $y => $mots) {
|
||||||
|
foreach($mots as $mot) {
|
||||||
|
$longueur = strlen($mot);
|
||||||
|
if (!isset($_SESSION["dico"][$longueur])) $_SESSION["dico"][$longueur] = [];
|
||||||
|
$_SESSION["dico"][$longueur][$mot] = $this->dico[$longueur][$mot];
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function load($id)
|
public function load($id)
|
||||||
@ -213,6 +228,8 @@ class Grille implements ArrayAccess
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$this->dico = $_SESSION["dico"];
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,7 +10,7 @@ $cote = 20;
|
|||||||
// Dimensions du SVG
|
// Dimensions du SVG
|
||||||
$width = $colonnes * $cote; // Largeur proportionnelle au nombre de colonnes
|
$width = $colonnes * $cote; // Largeur proportionnelle au nombre de colonnes
|
||||||
$height = $lignes * $cote; // Hauteur proportionnelle au nombre de lignes
|
$height = $lignes * $cote; // Hauteur proportionnelle au nombre de lignes
|
||||||
$rectRadius = 7; // Rayon des coins arrondis du rectangle
|
$rectRadius = 20; // Rayon des coins arrondis du rectangle
|
||||||
|
|
||||||
// Création du document XML
|
// Création du document XML
|
||||||
$doc = new DOMDocument('1.0', 'UTF-8');
|
$doc = new DOMDocument('1.0', 'UTF-8');
|
||||||
|
Loading…
x
Reference in New Issue
Block a user