IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Pascal Discussion :

Représentation du jeu du moulin


Sujet :

Pascal

  1. #1
    Rédacteur/Modérateur

    Avatar de Roland Chastain
    Homme Profil pro
    Enseignant
    Inscrit en
    Décembre 2011
    Messages
    4 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 4 102
    Points : 15 588
    Points
    15 588
    Billets dans le blog
    9
    Par défaut Représentation du jeu du moulin
    Bonjour !

    J'aimerais bien travailler sur le jeu du moulin, qui est connu aussi sous d'autre noms. Si vous ne connaissez pas, voici deux (très beaux) logiciels qui permettent d'y jouer :


    Comment vous y prendriez-vous pour représenter la table de jeu ? Je ne parle de la représentation visuelle, mais de la représentation logique. Comment désigner les cases ou les emplacements ? Comment déterminer que deux cases sont reliées ? Comment déterminer que trois cases sont alignées ?

    Le problème est d'autant plus amusant que le jeu a des variantes (on peut s'en faire une idée en regardant cette page).

    Il faut donc imaginer une notation pour les coups, déterminer si les coups sont possibles, s'ils ont pour résultat un moulin (un alignement de trois pièces)...

    Qu'en pensez-vous ? Pour ma part, à première vue, je trouve ça assez compliqué.

  2. #2
    Responsable Pascal, Lazarus et Assembleur


    Avatar de Alcatîz
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Mars 2003
    Messages
    7 975
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ressources humaines
    Secteur : Service public

    Informations forums :
    Inscription : Mars 2003
    Messages : 7 975
    Points : 59 740
    Points
    59 740
    Billets dans le blog
    2
    Par défaut
    Bonjour Roland,

    Effectivement cela paraît assez compliqué. Pour la représentation en mémoire, je partirais de l'existence de 24 intersections et de 16 moulins, chaque intersection ayant 2 ou 3 intersections adjacentes et appartenant à 2 moulins :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    type
     
      TIntersection = Record
        Valeur : Integer;
        IndiceAdjacent1 : Integer;
        IndiceAdjacent2 : Integer;
        IndiceAdjacent3 : Integer;
        IndiceMoulin1 : Integer;
        IndiceMoulin2 : Integer;
      end;
     
      TMoulin = Record
        Complet : Boolean;
        IndiceIntersection1 : Integer;
        IndiceIntersection2 : Integer;
        IndiceIntersection3 : Integer;
      end;
     
      TIntersections = Array [1..24] of TIntersection;
      TMoulins = Array [1..16] of TMoulin;
    Chaque changement de valeur d'une intersection se reporterait ainsi sur les deux moulins qu'elle concerne et il serait aisé d'accéder à la complétude (ou non) des deux moulins liés à chaque intersection. Une version objet ou avec des enregistrements étendus serait bien sûr plus élégante. D'autres auront peut-être des idées plus performantes.

  3. #3
    Expert confirmé
    Avatar de BeanzMaster
    Homme Profil pro
    Amateur Passionné
    Inscrit en
    Septembre 2015
    Messages
    1 899
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Amateur Passionné
    Secteur : Tourisme - Loisirs

    Informations forums :
    Inscription : Septembre 2015
    Messages : 1 899
    Points : 4 355
    Points
    4 355
    Billets dans le blog
    2
    Par défaut
    Salut Roland,

    cela me fait penser à un "morpion" sous stéroïde. L'emploi d'un algo genre NegaMax / MinMax devrait permettre de trouver si il y un "moulin" correcte et/ou permettre de déterminer les mouvements de l'IA.

    Pour ce qui est de la structure, je ferai peut-être quelques chose orienté objet dans ce style :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    Type
      TPlayerType = (ptHuman, ptComputer);
     
      TCellStatus = (csUndefined, csPlayer1, csPlayer2);
      TBoard = Array of TCellStatus;//Array[0..cMaxBoardSize-1] of TCellStatus;  
      TMills = Array of Array of Byte;
     
     
      TBoardGame = class
      private
         FMaxBoardSize : Byte;
         FMaxVoisin : Byte;
         FBoardName : String;
         FBoardWidth, FBoardHeight : Byte;
     
         FBoard : TBoard;
     
         FMaxMills : Byte;
         FMaxMillTokens : Byte;
         FMills : TMills
       // Exemple  FMills avec FMaxMills = 16 FMaxMillToken = 3
       // Moulins horizontaux
      { (0, 1, 2),      (3, 4, 5),      
       (6, 7, 8),      (9, 10, 11),   
       (12, 13, 14), (15, 16, 17),
       (18, 19, 20), (21, 22, 23),
       // Moulins Verticaux
       (0, 9, 21),     (3, 10, 18),
       (6, 11, 15),   (1, 4, 7),
       (16, 19, 22), (8, 12, 17),
       (5, 13, 20),  (2,14,23) }
     
      protected
     
      public     
         Constructor Create;
         Destructor Destroy;
     
         function getBoard : TBoard;
     
         property MaxBoardSize : Byte read FMaxBoardSize;
         property MaxVoisin : Byte read MaxVoisin;
         property BoardName : String read FBoardName;
         property FBoardWidth : Byte read FBoardWidth;
         property BoardHeight : Byte read FBoardHeight;
         property MaxMills : Byte read FMaxMills;
         property MaxMillTokens : Byte read FMaxMillTokens;
     
         property Mill[MillIndex : Integer; TokenIndex : Integer] : Integer read getMillToken;
         property Cell[Index : Integer] : TCellStatus read getCell write setCell
      end;
     
      TPlayer = Class
      private
        FBoard : TBoardGame;
        FPlayerType : TPlayerType;
     
        function CanMove(OldPos, NewPos : Integer) : Boolean;
      public
         Constructor Create(ABoard : TBoardGame);
     
         procedure SetMove(NewPos : Integer):
         procedure UpdateMove(OldPos, NewPos : Integer):
     
         function CheckIfWin : Boolean;
     
         property PlayerType : TPlayerType read FPlayerType write FPlayerType;
      end;
    Il manque quelques éléments pour obtenir des plateaux de jeux persos. A voir comment ajouter, personnaliser la position des cases en fonction de l'algo pour dessiner les grilles de jeu. On pourrait également ajouter un tableau pour stocker tous les voisins à une position X (un peu comme le FMills) Ce qui simplifierait les tests.

    A+

    Jérôme

  4. #4
    Rédacteur/Modérateur

    Avatar de Roland Chastain
    Homme Profil pro
    Enseignant
    Inscrit en
    Décembre 2011
    Messages
    4 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 4 102
    Points : 15 588
    Points
    15 588
    Billets dans le blog
    9
    Par défaut
    Citation Envoyé par Alcatîz Voir le message
    Bonjour Roland,

    Effectivement cela paraît assez compliqué. Pour la représentation en mémoire, je partirais de l'existence de 24 intersections et de 16 moulins, chaque intersection ayant 2 ou 3 intersections adjacentes et appartenant à 2 moulins :
    Intéressant. C'est déjà un peu plus clair. Merci !

    Je prends encore quelques jours pour jouer et bien assimiler les règles, et je passe aux travaux pratiques.

  5. #5
    Rédacteur/Modérateur

    Avatar de Roland Chastain
    Homme Profil pro
    Enseignant
    Inscrit en
    Décembre 2011
    Messages
    4 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 4 102
    Points : 15 588
    Points
    15 588
    Billets dans le blog
    9
    Par défaut
    Citation Envoyé par BeanzMaster Voir le message
    Pour ce qui est de la structure, je ferai peut-être quelques chose orienté objet dans ce style :
    Merci Jérôme pour toutes ces idées. Je vais m'en inspirer.

    Au fait, j'ai encore trouvé un autre logiciel, qui a quelques années, mais qui fonctionne parfaitement : http://belasius.com/mulino/

    Il y a aussi celui-ci, en C, qui est plus basique, mais qui fonctionne bien aussi : https://github.com/paul-maxime/merreles

    Ce serait amusant de faire un tournoi de robots. Il faudrait inventer un protocole... Bon, nous n'en sommes pas là, mais l'idée me plaît bien. Ça m'a même presque empêché de dormir.

  6. #6
    Expert confirmé
    Avatar de anapurna
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    3 461
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 461
    Points : 5 918
    Points
    5 918
    Par défaut
    salut

    un tableau ou un arbre

    tu as un maximum 4 connexions

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
       Directions = (Haut,Bas,Droite,Gauche)
     
    TCellule = Class
     
    TConnexion = Class 
      Voisin : Array[Directions] of TCellule;
    End
     
    TCellule = Class 
       Ident         : integer;
       Position     : Tpos;
       Connexion : TConnexion;
    End;

  7. #7
    Rédacteur/Modérateur
    Avatar de Andnotor
    Inscrit en
    Septembre 2008
    Messages
    5 861
    Détails du profil
    Informations personnelles :
    Localisation : Autre

    Informations forums :
    Inscription : Septembre 2008
    Messages : 5 861
    Points : 13 686
    Points
    13 686
    Par défaut
    Je partirais sur quelque chose de ce style :

    Des pions valant 1 (blanc) ou -1 (noir), un moulin complet valant +3 ou -3.
    Des moulins contenant la liste de leurs points.
    Des points contenant leur couleur actuelle, la liste des moulins les contenant et les points connectés pour déplacement.
    Des joueurs avec leur couleur et les points qu'ils possèdent.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    type
      TMoveResult = (tmDenied, tmPartial, tmFull); // Point déjà occupé, moulin partiel ou complet
     
      TCell = class;
     
      TMill = class
        Cells :array of TCell;
        function IsFull :boolean;  // +3: blanc, -3:noir
      end;
     
      TCell = class
        Color :shortint;           // 0: vide, 1: blanc, -1:noir
        Mills :array of TMill;     // Moulins concernés
        Cells :array of TCell;     // Points connexes pour déplacement
        function Move(aDest :TCell) :TMoveResult;
      end;
     
      TPlayer = class
        Color :shortint;           // 1: blanc, -1:noir (constante)
        Cells :array of TCell;     // Points avec sa couleur, augmente de 1 à 9 puis se réduit de 9 à 2
      end;
     
      TBoard = class
        Players :array[boolean] of TPlayer;
        Current :boolean;                     // Joueur actuel
        Grid : array of array of TCell;       // Grille contenant ou non (nil) un point
        function Move(aSource, aDest :TCell) :TMoveResult;
      end;
    Sur OnMouseDown, contrôle de la validité du pion pour le joueur actuel et sur OnMouseUp TBoard.Move appelle TCell.Move pour contrôler la validité du déplacement puis assigne la cellule au joueur qui la remplit de sa couleur et éventuellement retire un pion adverse, etc, etc.

  8. #8
    Rédacteur/Modérateur

    Avatar de Roland Chastain
    Homme Profil pro
    Enseignant
    Inscrit en
    Décembre 2011
    Messages
    4 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 4 102
    Points : 15 588
    Points
    15 588
    Billets dans le blog
    9
    Par défaut
    Merci pour vos précieuses contributions.

    Citation Envoyé par Andnotor Voir le message
    Sur OnMouseDown, contrôle de la validité du pion pour le joueur actuel et sur OnMouseUp TBoard.Move appelle TCell.Move pour contrôler la validité du déplacement puis assigne la cellule au joueur qui la remplit de sa couleur et éventuellement retire un pion adverse, etc, etc.
    Dans un premier temps je pense faire une application console, où l'on entre les coups au clavier.

  9. #9
    Rédacteur/Modérateur

    Avatar de Roland Chastain
    Homme Profil pro
    Enseignant
    Inscrit en
    Décembre 2011
    Messages
    4 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 4 102
    Points : 15 588
    Points
    15 588
    Billets dans le blog
    9
    Par défaut
    Petite parenthèse, sur le nom du jeu. Si l'on en croit Littré, le nom du jeu serait... marelle. Je suis allé voir aussi l'article moulin : on n'y trouve aucune mention d'un jeu qui porterait ce nom.

    P.-S. Plus d'informations dans cet article.

  10. #10
    Rédacteur/Modérateur

    Avatar de Roland Chastain
    Homme Profil pro
    Enseignant
    Inscrit en
    Décembre 2011
    Messages
    4 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 4 102
    Points : 15 588
    Points
    15 588
    Billets dans le blog
    9
    Par défaut
    Je n'ai pas oublié cette discussion. J'ai regardé d'un peu plus près ce programme-ci. Je l'ai trouvé très bien écrit. J'ai bien envie de le traduire en Pascal.

    Autrement j'ai commencé à réfléchir à la façon de numéroter les intersections.

    Code X : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    7   000------------001------------002
         |              |              |
    6    |   008-------009-------010   |
         |    |         |         |    |
    5    |    |   016--017--018   |    |
         |    |    |         |    |    |
    4   007--015--023       019--011--003
         |    |    |         |    |    |
    3    |    |   022--021--020   |    |
         |    |         |         |    |
    2    |   014-------013-------012   |
         |              |              |
    1   006------------005------------004
    
         a    b    c    d    e    f    g

    La plupart des programmes que j'ai vus numérotent les lignes de haut en bas. Moi j'ai tendance à préférer comme ça. Mais il vaudrait peut-être mieux suivre l'usage le plus commun.

    P.-S. J'ai trouvé aussi ce livre, qui a l'air intéressant : Récréations mathématiques

  11. #11
    Rédacteur/Modérateur

    Avatar de Roland Chastain
    Homme Profil pro
    Enseignant
    Inscrit en
    Décembre 2011
    Messages
    4 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 4 102
    Points : 15 588
    Points
    15 588
    Billets dans le blog
    9
    Par défaut
    J'ai mis à jour le petit programme en C dont j'avais parlé plus haut.

    Ci-joint le programme en Pascal que j'ai écrit pour fabriquer l'image du plateau.
    Images attachées Images attachées  
    Fichiers attachés Fichiers attachés

  12. #12
    Responsable Pascal, Lazarus et Assembleur


    Avatar de Alcatîz
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Mars 2003
    Messages
    7 975
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ressources humaines
    Secteur : Service public

    Informations forums :
    Inscription : Mars 2003
    Messages : 7 975
    Points : 59 740
    Points
    59 740
    Billets dans le blog
    2
    Par défaut
    Bonjour Roland,

    Je retiens en passant le site https://opengameart.org/.

  13. #13
    Rédacteur/Modérateur

    Avatar de Roland Chastain
    Homme Profil pro
    Enseignant
    Inscrit en
    Décembre 2011
    Messages
    4 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 4 102
    Points : 15 588
    Points
    15 588
    Billets dans le blog
    9
    Par défaut
    Oui ce site est très utile.

    Pour la représentation des données, je pense partir de ton idée, avec une petite modification.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
     
    type
      TIntersection = Record
        Valeur: Integer;
        IndiceAdjacent: Array[1..4] of Integer;
        IndiceMoulin: Array[1..2] of Integer;
      end;
     
      TMoulin = Record
        Complet: Boolean;
        IndiceIntersection: Array[1..3] of Integer;
      end;
     
      TIntersections = Array [1..24] of TIntersection;
      TMoulins = Array [1..16] of TMoulin;
     
    const
      CIntersections: TIntersections = (
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
     
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
     
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0)),
        (Valeur: 0; IndiceAdjacent: (0, 0, 0, 0); IndiceMoulin: (0, 0))
      );
      CMoulins: TMoulins = (
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0)),
        (Complet: FALSE; IndiceIntersection: (0, 0, 0))
      );
     
    var
      Intersections: TIntersections;
     
    begin
      Intersections := CIntersections;
    end.
    (Pour le moment j'ai mis des zéros partout parce que je ne suis pas encore décidé sur la manière de numéroter les cases.)

    Je pourrais aussi reprendre l'idée d'anapurna, array[TDirection], au lieu de array[1..4].

    L'idée d'un tableau dynamique (exemple d'Andnotor) est peut-être préférable à certains points de vue, mais la quantité de code qu'il faudra pour initialiser tout ça ! Enfin je ne sais pas, j'y réfléchis encore.

  14. #14
    Rédacteur/Modérateur

    Avatar de Roland Chastain
    Homme Profil pro
    Enseignant
    Inscrit en
    Décembre 2011
    Messages
    4 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 4 102
    Points : 15 588
    Points
    15 588
    Billets dans le blog
    9
    Par défaut
    On pourrait considérer le plateau de jeu comme un damier, où le mode de déplacement des pièces dépend de la case où elles se trouvent.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
     
    uses
    {$IFDEF unix}
      cThreads,
    {$ENDIF}
      SysUtils, ptcCrt, ptcGraph;
     
    const
      A = 41;
      B = A div 2;
     
    var
      gd, gm: smallint;
      i, j: integer;
     
    begin
      gd := VESA;
      gm := InstallUserMode(7 * A, 7 * A, 16);
    { Procédure disponible dans la dernière version de PTCGraph :
      https://sourceforge.net/projects/ptcpas/ }
     
      if gm < 0 then
      begin
        Writeln(ErrOutput, 'Error installing user mode: ', GraphErrorMsg(gm));
        Halt(1);
      end;
     
      WindowTitle := 'Moulin';
      InitGraph(gd, gm, '');
     
     
      SetBkColor(Blue);
      SetColor(LightMagenta);
      SetFillStyle(SolidFill, LightBlue);
     
      ClearViewPort;
     
      for i := 0 to 7 do
        for j := 0 to 7 do
          if (i + j) mod 2 = 0 then
            Bar(A * i, A * j, A * i + A - 1, A * j + A - 1);
     
      Rectangle(0 * A + B, 0 * A + B, 6 * A + B, 6 * A + B);
      Rectangle(1 * A + B, 1 * A + B, 5 * A + B, 5 * A + B);
      Rectangle(2 * A + B, 2 * A + B, 4 * A + B, 4 * A + B);
     
      MoveTo(0 * A + B, 3 * A + B); LineTo(2 * A + B, 3 * A + B);
      MoveTo(4 * A + B, 3 * A + B); LineTo(6 * A + B, 3 * A + B);
      MoveTo(3 * A + B, 0 * A + B); LineTo(3 * A + B, 2 * A + B);
      MoveTo(3 * A + B, 4 * A + B); LineTo(3 * A + B, 6 * A + B);
     
      SetFillStyle(SolidFill, LightMagenta);
     
      Bar(0 * A + B - 2, 0 * A + B - 2, 0 * A + B + 2, 0 * A + B + 2); Bar(3 * A + B - 2, 0 * A + B - 2, 3 * A + B + 2, 0 * A + B + 2); Bar(6 * A + B - 2, 0 * A + B - 2, 6 * A + B + 2, 0 * A + B + 2);
      Bar(1 * A + B - 2, 1 * A + B - 2, 1 * A + B + 2, 1 * A + B + 2); Bar(3 * A + B - 2, 1 * A + B - 2, 3 * A + B + 2, 1 * A + B + 2); Bar(5 * A + B - 2, 1 * A + B - 2, 5 * A + B + 2, 1 * A + B + 2);
      Bar(3 * A + B - 2, 2 * A + B - 2, 3 * A + B + 2, 2 * A + B + 2);
      Bar(0 * A + B - 2, 3 * A + B - 2, 0 * A + B + 2, 3 * A + B + 2); Bar(1 * A + B - 2, 3 * A + B - 2, 1 * A + B + 2, 3 * A + B + 2); Bar(2 * A + B - 2, 3 * A + B - 2, 2 * A + B + 2, 3 * A + B + 2); Bar(4 * A + B - 2, 3 * A + B - 2, 4 * A + B + 2, 3 * A + B + 2); Bar(5 * A + B - 2, 3 * A + B - 2, 5 * A + B + 2, 3 * A + B + 2); Bar(6 * A + B - 2, 3 * A + B - 2, 6 * A + B + 2, 3 * A + B + 2);
      Bar(3 * A + B - 2, 4 * A + B - 2, 3 * A + B + 2, 4 * A + B + 2);
      Bar(1 * A + B - 2, 5 * A + B - 2, 1 * A + B + 2, 5 * A + B + 2); Bar(3 * A + B - 2, 5 * A + B - 2, 3 * A + B + 2, 5 * A + B + 2); Bar(5 * A + B - 2, 5 * A + B - 2, 5 * A + B + 2, 5 * A + B + 2);
      Bar(0 * A + B - 2, 6 * A + B - 2, 0 * A + B + 2, 6 * A + B + 2); Bar(3 * A + B - 2, 6 * A + B - 2, 3 * A + B + 2, 6 * A + B + 2); Bar(6 * A + B - 2, 6 * A + B - 2, 6 * A + B + 2, 6 * A + B + 2);
     
      ReadKey;
      CloseGraph;
    end.
    Images attachées Images attachées  

  15. #15
    Expert confirmé

    Homme Profil pro
    Directeur de projet
    Inscrit en
    Mai 2013
    Messages
    1 523
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2013
    Messages : 1 523
    Points : 4 835
    Points
    4 835
    Par défaut Vue d'avion
    Bonjour,

    Je vois que le sujet motive. Une petite participation sur la représentation des données. J'ai juste imaginé que le plateau représentait un cube vu d'avion avec une forte perspective ce qui donne un cube de ce type :

    Nom : Jeu des moulins.png
Affichages : 238
Taille : 75,9 Ko

    Les possibilités d'indexation de Pascal permettent d'avoir un tableau sympathique [-1..1, -1..1, -1..1] qui ne gaspille que peu de place 27/24.

    Un point milieu de coté se détecte simplement par (x and y) = 0.

    Salutations

  16. #16
    Rédacteur/Modérateur

    Avatar de Roland Chastain
    Homme Profil pro
    Enseignant
    Inscrit en
    Décembre 2011
    Messages
    4 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 4 102
    Points : 15 588
    Points
    15 588
    Billets dans le blog
    9
    Par défaut
    Citation Envoyé par Guesset Voir le message
    Une petite participation sur la représentation des données.
    Je trouve cette idée très astucieuse, et si je n'ai pas répondu, c'est parce que je n'ai pas trouvé le temps de travailler sur ce projet.

    Aujourd'hui je reviens à cette discussion parce que je viens de découvrir un projet qui a l'air génial : Sanmill

    L'adversaire artificiel est une application console, comme un moteur d'échecs, utilisant un protocole dérivé du protocole UCI. Le projet inclut trois interfaces graphiques. J'ai compilé l'interface Qt, qui est très belle. Je n'ai pas encore essayé les autres (ne connaissant pas les bibliothèques utilisées).

    On pourrait écrire un moteur en Pascal, et utiliser l'une de ces interfaces...
    Images attachées Images attachées  

Discussions similaires

  1. Représentation d'un plateau de jeu
    Par Cybersad dans le forum Général Python
    Réponses: 1
    Dernier message: 04/12/2019, 10h35
  2. Réponses: 362
    Dernier message: 05/04/2018, 14h59
  3. représenter graphiquement le jeu de données
    Par danap22 dans le forum Débuter
    Réponses: 0
    Dernier message: 08/12/2016, 14h27
  4. Réponses: 1
    Dernier message: 29/02/2016, 19h19
  5. [RPG] Déroulement du jeu : comment le représenter en mémoire ?
    Par TheDrev dans le forum Développement 2D, 3D et Jeux
    Réponses: 1
    Dernier message: 31/08/2009, 21h20

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo