Latest Updates: application RSS

  • Serieswatcher: Alertes mes séries tv préférées

    admin 22 h 01 min on 30 novembre 2009 | 0 Permalink | Reply
    Tags: application, , serieswatcher

    Serieswatcher projet
    Projet java réalisé sous Eclipse : Serieswatcher !

    Début d’un nouveau projet nommé Serieswatcher. Ce projet consiste à créer un logiciel en java qui permet d’être mis au courant, d’être averti grâce à une alerte, des dernières dates de sorties des épisodes d’une série tv donnée. Par exemple je suis fan de la série Lost, Dexter et Greys anatomy, et j’aime regarder les épisodes sur internet dés qu’ils sortent. Serieswatcher permettra à tout fan de série tv de pouvoir être mis au courant directement lorsqu’un nouvel épisode est à l’affiche.

    Dans un premier temps, le projet consiste à parser une page html afin d’en extraire les multiples infos pertinentes sur une série tv précise. Certains sites web proposent des informations complètes sur les dates de sorties des séries. Néanmoins, il peut être intéressant d’être directement alerter, mis sous alerte, lorsqu’un nouvel épisode sort en tv.

    La première version de Serieswatcher pourrait être une version qui s’installe sur pc, avec icône dans la barre des taches qui émet une alerte dans la barre de taches en cas de nouvel épisode des séries tv choisis. Plus tard, peut-être une version pour gsm (Android), une version sous forme de ria (appli Facebook, applications web,…).

    Voici une première ébauche des classes qui composent ce projet. Serieswatcher dans sa première version, utilise déjà plusieurs classes déjà prédéfini dans le jdk. Par exemple la classe Pattern, la classe Matcher qui sont deux classes très importante pour parser le contenu d’une page html, afin de trouver des mises à jour d’informations. Excellent pour s’initier doucement aux concepts d’expressions régulières. L’expression à chercher se trouve dans le pattern, le matcher est le moteur de comparaison entre le modèle pattern compilé et le matcher.

    La classe urlConnection provenant de java.net pour se connecter à un site web avec java.

    Les objets de type LinkedList aussi sont utilisées dans Serieswatcher. Chaque saison, chaque épisode est contenu dans une liste doublement chainée LinkedList. Pas de tableau ici, car les tableaux en java ne peuvent grandir. Une LinkedList est donc mieux adaptée.

    Dans cette première version du logiciel Serieswatcher, une première interface graphique (gui) super basique à été commencée, il faut bien entendu continuer de la développer.
    Voici les classes qui composent, lors de cette version, le projet Serieswatcher (Main, Site, Serie, Saison, Episode, Modele, Vue, Controleur)

    Classe Main

    
    public class Main {
    	public static void main(String[] args) {
    		// on instancie les classes mvc, mais la Gui doit encore être programmée
    		Controleur controleur = new Controleur();
    		Vue vue = new Vue(controleur);
    		Modele modele = new Modele(controleur);
    		controleur.setVue(vue);
    		controleur.setModele(modele);
    
    		vue.pack();
    		vue.setVisible(true);
    	}
    }
    

    Affichage de la classe Site

    import java.io.BufferedReader;
    import java.io.InputStreamReader;
    import java.net.URL;
    import java.net.URLConnection;
    import java.util.LinkedList;
    import java.util.regex.Matcher;
    import java.util.regex.Pattern;
    
    public class Site {
    	/**
    	 * Cette méthode permet de récupérer une page HTTP (en HTML) depuis un site
    	 * donné avec un nom de série donné sous forme d'une liste chainée.
    	 *
    	 * @pre    serieName doit être le nom d'une série dans le format du
    	 * 		 	site (ex.: "PrisonBreak" ok, "Prison Break" pas ok)
    	 * @return une page HTML sous forme d'une liste chainée de String
    	 * 			où chaque String contient une ligne du code source de la page
    	 *
    	 * @todo : traiter le cas où la série n'existe pas + lever exception
    	 */
    	public static LinkedList<String> getHttpPage(String serieName) {
    		String sURL = "http://www.epguides.com/" + serieName;
    		String line = ""; // empty HTML page
    		LinkedList<String> pageCodeList = new LinkedList<String>();
    
    		try {
    			URL epguides = new URL(sURL);
    	        URLConnection conn = epguides.openConnection();
    
    	        // version BufferedReader
    	        BufferedReader bReader = new BufferedReader(new InputStreamReader(conn.getInputStream()));
    
    	        while((line = bReader.readLine()) != null) {
    	        	pageCodeList.add(line); // on l'ajoute dans la liste
    	        }
    
    // version Scanner
    /*	        String page2 = "";
    	        Scanner scan = new Scanner(conn.getInputStream());
    
    	        while(scan.hasNext()) {
    	        	page2 += scan.next();
    	        }
    */
    		} catch(Exception e) {
    			e.printStackTrace(); // todo : traiter avec GUI
    		}
    
    		return pageCodeList;
    	}
    
    	/**
    	 * Cette méthode permet de tester notre pattern matcher sur le code
    	 * source d'une page HTML.
    	 *
    	 * @pre  htmlSource est le code source HTML d'une page qui contient des
    	 * 	      informations au sujet d'une série donnée
    	 * @post les lignes qui matchent le pattern (voir code) seront affichées
    	 *        à l'écran
    	 */
    	public static void showMatchingLines(LinkedList<String> htmlSource) {
    		Pattern pattern = Pattern.compile("^\\s*\\d+\\.{0,1}\\s+.*$");
    		//pattern = Pattern.compile("^\\s*\\d+\\.{0,1}\\s+4{1}-.*$"); // récupère les épisodes de la saison i
    
    		String line = "";
    		Matcher matcher;
    
    		for(int i = 0; i < htmlSource.size(); i++) {
    			line = htmlSource.get(i);
    			matcher = pattern.matcher(line);
    			if(matcher.find()) {
    				System.out.println(line);
    			}
    		}
    	}
    }
    

    Affichage de la classe Série

    import java.util.Calendar;
    import java.util.LinkedList;
    import java.util.regex.Matcher;
    import java.util.regex.Pattern;
    
    public class Serie {
        String name; // ex.: Prison Break
        String urlName; // ex.: PrisonBreak
        Calendar startDate;
        Calendar endDate;
        LinkedList<Season> seasonsList;
    
        public Serie() {
    	name = "<Unknown>";
    	startDate = null;
    	endDate = null;
    	seasonsList = new LinkedList<Season>();
        }
    
        /**
         * Cette méthode permet de récupérer un objet de type Série
         * totalement complet et correctement initialisé.
         *
         * @pre    serieName doit être le nom d'une série dans le format du
         * 		 	site (ex.: "PrisonBreak" ok, "Prison Break" pas ok) et
         * 			qui existe
         * @return une série correctement construire et complète
         */
        public static Serie serieBuilder(String serieName) {
    	LinkedList<String> htmlSource = Site.getHttpPage(serieName);
    
    	Serie serie = new Serie();
    	int seasonIndex = 1;
    	boolean currentSeasonExists = true;
    
    	Pattern pattern;
    	Matcher matcher;
    
    	// on commence la partie pattern matching pour les épisodes de chaque saison
    	while(currentSeasonExists) {
    	    Season currentSeason = new Season(serie, seasonIndex);
    
    	    pattern = Pattern.compile("^\\s*\\d+\\.{0,1}\\s+" + seasonIndex + "{1}-.*$"); // récupère les épisodes de la saison i
    
    	    // on parcourt tout le code source, ligne par ligne
    	    for(int i = 0; i < htmlSource.size(); i++) {
    		String line = htmlSource.get(i); // ligne courante
    		matcher = pattern.matcher(line);
    		if(matcher.find()) {
    		    // si on trouve, cela signifie que 'line' est une ligne qui représente un épisode
    		    // de la saison 'currentSeason'
    		    Episode ep = Episode.episodeBuilder(currentSeason, line);
    		    currentSeason.episodesList.add(ep);
    		}
    	    }
    
    	    if(currentSeason.episodesList.size() > 0) {
    		serie.seasonsList.add(currentSeason);
    		seasonIndex++;
    	    } else {
    		currentSeasonExists = false;
    	    }
    	}
    
    	return serie;
        }
    }
    

    Affichage de la classe Season

    import java.util.LinkedList;
    
    public class Season {
    	int number;
    	Serie serie;
    	LinkedList<Episode> episodesList;
    
    	public Season(Serie s, int i) {
    		serie = s;
    		number = i;
    		episodesList = new LinkedList<Episode>();
    	}
    }
    

    Affichage classe Episode

    import java.util.Calendar;
    import java.util.GregorianCalendar;
    import java.util.regex.Matcher;
    import java.util.regex.Pattern;
    
    public class Episode {
        String title;
        Season season;
        Calendar airDate;
        String link;
        int number; // numéro de l'épisode au sein de la saison
    
        /**
         * Cette méthode nous permet de récupérer les informations d'un épisode
         * à partir d'une ligne de code source.
         *
         * @pre    epSeason est l'object qui représente la saison de l'épisode
         * 		   sourceLine est une ligne de code source qui contient des informations
         * 			sur un épisode donné
         * @return un épisode construit à partir des informations contenues dans sourceLine
         */
        public static Episode episodeBuilder(Season epSeason, String sourceLine) {
    	Pattern pat;
    	Matcher mat;
    
    	Episode ep = new Episode(); // on crée un objet Episode vide
    	int epNumber = -1;
    	Calendar airDate = new GregorianCalendar(0,0,0);
    	String link = "N/A";
    	String title = "N/A";
    
    	pat = Pattern.compile("\\d{1,}"); // matching numéro épisode
    	mat = pat.matcher(sourceLine);
    	if(mat.find())
    	    epNumber = Integer.parseInt(sourceLine.substring(mat.start(), mat.end()));
    
    	pat = Pattern.compile("\\d{1,2}\\s{0,1}/{0,1}[a-zA-Z]{3}\\s{0,1}/{0,1}\\d{2}"); // matching air date de l'épisode
    	mat = pat.matcher(sourceLine);
    	if(mat.find()) {
    	    String matchedDate = sourceLine.substring(mat.start(), mat.end());
    
    	    // pour construire le Calendar, il nous faut le day, month number et year
    	    String day = "N/A";
    	    pat = Pattern.compile("^\\d{1,2}");
    	    mat = pat.matcher(matchedDate);
    	    if(mat.find()) day = matchedDate.substring(mat.start(), mat.end());
    
    	    String month = "N/A";
    	    pat = Pattern.compile("[a-zA-Z]{3}");
    	    mat = pat.matcher(matchedDate);
    	    if(mat.find()) month = matchedDate.substring(mat.start(), mat.end());
    
    	    String year = "N/A";
    	    pat = Pattern.compile("\\d{2}$");
    	    mat = pat.matcher(matchedDate);
    	    if(mat.find()) year = matchedDate.substring(mat.start(), mat.end());
    
    	    // conversion du month en son numéro de mois dans l'année (voir doc méthode)
    	    int monthNb = convertToMonthNumber(month);
    
    	    airDate = new GregorianCalendar(Integer.parseInt(year), monthNb, Integer.parseInt(day));
    	}
    
    	pat = Pattern.compile("http://.*\"");
    	mat = pat.matcher(sourceLine);
    	if(mat.find()) link = sourceLine.substring(mat.start(), mat.end()-1);
    
    	pat = Pattern.compile(">.*</a>");
    	mat = pat.matcher(sourceLine);
    	if(mat.find()) title = sourceLine.substring(mat.start()+1, mat.end()-4);
    
    	// remplissage des attributs de l'objet
    	ep.number = epNumber;
    	ep.airDate = airDate;
    	ep.link = link;
    	ep.title = title;
    	ep.season = epSeason;
    
    	return ep;
        }
    
        /**
         * Cette méthode convertit un nom de mois anglais de trois caractères
         * en son numéro dans l'année (ex.: Mar => 3).
         *
         * @pre    month est un mois anglais de trois caractères (Jan, Feb, Mar, ...)
         * @return le numéro du mois dans l'année,
         * 			sinon -1 si month n'est pas un mois valide
         */
        public static int convertToMonthNumber(String month) {
    	String[] monthsTab = {"Jan", "Feb", "Mar", "Apr", "May", "Jun",
    		"Jul", "Aug", "Sep", "Oct", "Nov", "Dec"};
    	for(int i = 0; i < monthsTab.length; i++) {
    	    // on fait la comparaison en lower case (pour être sûrs)
    	    if((monthsTab[i].toLowerCase()).equals(month.toLowerCase()))
    		return i+1;
    	}
    	return -1;
        }
    }
    

    Affichage classe vue

    import java.awt.event.ActionEvent;
    import java.awt.event.ActionListener;
    
    import javax.swing.BoxLayout;
    import javax.swing.JComboBox;
    import javax.swing.JFrame;
    import javax.swing.JPanel;
    import javax.swing.JScrollPane;
    
    @SuppressWarnings("serial")
    public class Vue extends JFrame {
        public Controleur controleur;
        public JComboBox serieChoice;
        public JComboBox seasonChoice;
        public JPanel contentPanel;
        public JPanel superPanel;
    
        public Vue(Controleur c) {
    	controleur = c;
    
    	// construction de l'interface graphique
    	buildGUI();
        }
    
        public void buildGUI() {
    	setTitle("Series Watcher v0.1");
    	superPanel = new JPanel();
    	BoxLayout bL = new BoxLayout(superPanel, BoxLayout.Y_AXIS);
    	superPanel.setLayout(bL);
    	add(superPanel);
    
    	serieChoice = new JComboBox(new String[]{"Lost", "PrisonBreak", "DesperateHousewives"});
    	serieChoice.addActionListener(new ActionListener() {
    	    @Override
    	    public void actionPerformed(ActionEvent e) {
    		controleur.updateSerie();
    	    }
    	});
    	seasonChoice = new JComboBox();
    	JScrollPane jScrollPane = new JScrollPane();
    	contentPanel = new JPanel();
    
    	jScrollPane.add(contentPanel);
    
    	superPanel.add(serieChoice);
    	superPanel.add(seasonChoice);
    	superPanel.add(jScrollPane);
        }
    
        public void showSeasonList(int nbSeasons) {
    	seasonChoice.removeAllItems();
    	for(int i = 0; i < nbSeasons; i++)
    	    seasonChoice.addItem("Season " + (i+1));
        }
    }
    

    Affichage classe modele

    
    public class Modele {
        public Controleur controleur;
    
        public Modele(Controleur c) {
    	controleur = c;
        }
    }
    

    Affichage de la classe controlleur

    
    public class Controleur {
        public Vue vue;
        public Modele modele;
    
        public void updateSerie() {
    	String serieName = (String) vue.serieChoice.getSelectedItem();
    	Serie serie = Serie.serieBuilder(serieName);
    	vue.showSeasonList(serie.seasonsList.size());
        }
    
        public void setVue(Vue v) {
    	vue = v;
        }
        public void setModele(Modele m) {
    	modele = m;
        }
    }
    

    note: il ne s’agit que d’une première version non finale de Serieswatcher. De nombreuses fonctionnalités doivent y être pensées et développées. Cette première version permet de se frotter à un premier projet de conception un peu plus costaud que de simples exercices d’algorithmes. Exercices sur les expressions régulières, la classe urlconnection pour récupérer le contenu d’une page web.

     
  • Calculatrice java: faire une calculette simple

    admin 15 h 15 min on 14 octobre 2009 | 1 Permalink | Reply
    Tags: application, ,

    Création d’une calculatrice simple en java :

    Voici le code commenté qui permet de créer une calculatrice (telle la calculatrice que l’on retrouve dans les accessoires Windows pré installés). Cette calculatrice est tout ce qu’il y a de plus simple, il ne s’agit pas d’une calculatrice de type scientifique. Néanmoins cet exercice sur la création d’une calculatrice permet de commencer à toucher aux interfaces graphiques en java. Les interfaces graphiques permettent au programme crée d’être visible et utilisable pour les utilisateurs auxquels un programme est destiné.

    Cet exemple de calculatrice en java est directement issu du livre Java pour enfant de Yakov Fain. Le code de cette calculatrice se décompose en 2 classes. La classe Moteur de calcul qui va permettre de formuler l’algorithme de calcul utilisée par la calculatrice. Et la classe calculatrice elle-même, qui reprend les caractéristiques de l’interface graphique que l’on souhaite utilisée pour construire la calculatrice.
    Code la classe moteur de calcul. Algorithmes qui permettent à la calculatrice de fonctionner.

    Après compilation du code par éclipse, la calculatrice devrait avoir cette aspect:
    calculatrice.jpg

    import java.awt.event.ActionListener;
    import java.awt.event.ActionEvent;
    import java.text.NumberFormat;
    import java.text.ParsePosition;
    import javax.swing.JButton;
    public class MoteurCalcul implements ActionListener {
    	Calculatrice parent; // une référence à la Calculatrice
    	char actionSélectionnée = ' '; // +, -, /, ou *
    	double résultatCourant = 0;
    	NumberFormat formatNombres = NumberFormat.getInstance();
    	// un objet capable de lire et présenter les nombres
    	// Le constructeur stocke la référence à la fenêtre
    	// Calculatrice dans la variable membre parent
    	MoteurCalcul(Calculatrice parent) {
    		this.parent = parent;
    	}
    	public void actionPerformed(ActionEvent événement) {
    		// Retrouve la source de l'action
    		JButton boutonCliqué = (JButton) événement.getSource();
    		String texteChampAffichage =
    			parent.champAffichage.getText();
    		double valeurAffichée = 0;
    		// Retrouve le nombre présenté dans le champ texte
    		// s'il n'est pas vide
    		if (!"".equals(texteChampAffichage)) {
    			valeurAffichée =
    				// analyse la chaîne de caractères
    				formatNombres.parse(
    						texteChampAffichage,
    						new ParsePosition(0) /* ne sert pas */).
    						// puis donne sa valeur en tant que double
    						doubleValue();
    		}
    		Object sourceEvénement = événement.getSource();
    		// Pour chaque bouton d'action, mémorise l'action
    		// sélectionnée, +, -, /, ou *, stocke la valeur courante
    		// dans la variable résultatCourant et vide le champ
    		// Affichage avant l'entrée du nombre suivant
    		if (sourceEvénement == parent.boutonPlus) {
    			actionSélectionnée = '+';
    			résultatCourant = valeurAffichée;
    			parent.champAffichage.setText("");
    		}
    		else if (sourceEvénement == parent.boutonMoins) {
    			actionSélectionnée = '-';
    			résultatCourant = valeurAffichée;
    			parent.champAffichage.setText("");
    		}
    		else if (sourceEvénement == parent.boutonDiviser) {
    			actionSélectionnée = '/';
    			résultatCourant = valeurAffichée;
    			parent.champAffichage.setText("");
    		}
    		else if (sourceEvénement == parent.boutonMultiplier) {
    			actionSélectionnée = '*';
    			résultatCourant = valeurAffichée;
    			parent.champAffichage.setText("");
    		}
    		else if (sourceEvénement == parent.boutonEgale) {
    			// Effectue les calculs en fonction de actionSélectionnée
    			// Modifie la valeur de la variable résultatCourant
    			// et affiche le résultat
    			if (actionSélectionnée == '+') {
    				résultatCourant += valeurAffichée;
    				// Convertit le résultat en le transformant en String
    				// à l'aide de formatNombres
    				parent.champAffichage.setText(
    						formatNombres.format(résultatCourant));
    			}
    			else if (actionSélectionnée == '-') {
    				résultatCourant -= valeurAffichée;
    				parent.champAffichage.setText(
    						formatNombres.format(résultatCourant));
    			}
    			else if (actionSélectionnée == '/') {
    				résultatCourant /= valeurAffichée;
    				parent.champAffichage.setText(
    						formatNombres.format(résultatCourant));
    			}
    			else if (actionSélectionnée == '*') {
    				résultatCourant *= valeurAffichée;
    				parent.champAffichage.setText(
    						formatNombres.format(résultatCourant));
    			}
    		}
    		else {
    			// Pour tous les boutons numériques, ajoute le libellé
    			// du bouton au champ texte
    			String libelléBoutonCliqué = boutonCliqué.getText();
    			parent.champAffichage.setText(texteChampAffichage +
    					libelléBoutonCliqué);
    		}
    	}
    }
    

    Code de la classe Moteurcalcul qui défini un algorithme de calcul pour la calculatrice.

    import javax.swing.*;
    import java.awt.GridLayout;
    import java.awt.BorderLayout;
    public class Calculatrice {
    	// Déclare et instancie les composants de la fenêtre
    	JButton bouton0 = new JButton("0");
    	JButton bouton1 = new JButton("1");
    	JButton bouton2 = new JButton("2");
    	JButton bouton3 = new JButton("3");
    	JButton bouton4 = new JButton("4");
    	JButton bouton5 = new JButton("5");
    	JButton bouton6 = new JButton("6");
    	JButton bouton7 = new JButton("7");
    	JButton bouton8 = new JButton("8");
    	JButton bouton9 = new JButton("9");
    	JButton boutonVirgule = new JButton(",");
    	JButton boutonEgale = new JButton("=");
    	JButton boutonPlus = new JButton("+");
    	JButton boutonMoins = new JButton("-");
    	JButton boutonDiviser = new JButton("/");
    	JButton boutonMultiplier = new JButton("*");
    	JPanel contenuFenêtre = new JPanel();
    	JTextField champAffichage = new JTextField(30);
    	// Constructeur
    	Calculatrice() {
    		// Affecte le gestionnaire de disposition pour ce panneau
    		BorderLayout disposition = new BorderLayout();
    		contenuFenêtre.setLayout(disposition);
    		// Ajoute le champ d'affichage en haut de la fenêtre
    		contenuFenêtre.add("North", champAffichage);
    		// Crée le panneau avec le quadrillage qui contient
    		// 12 boutons – les 10 boutons numériques et ceux
    		// représentant la virgule et le signe égale
    		JPanel panneauChiffres = new JPanel();
    		GridLayout dispositionChiffres = new GridLayout(4, 3);
    		panneauChiffres.setLayout(dispositionChiffres);
    		panneauChiffres.add(bouton1);
    		panneauChiffres.add(bouton2);
    		panneauChiffres.add(bouton3);
    		panneauChiffres.add(bouton4);
    		panneauChiffres.add(bouton5);
    		panneauChiffres.add(bouton6);
    		panneauChiffres.add(bouton7);
    		panneauChiffres.add(bouton8);
    		panneauChiffres.add(bouton9);
    		panneauChiffres.add(bouton0);
    		panneauChiffres.add(boutonVirgule);
    		panneauChiffres.add(boutonEgale);
    		// Ajoute le panneau des chiffres à la zone centrale
    		// de la fenêtre
    		contenuFenêtre.add("Center", panneauChiffres);
    		// Crée le panneau avec le quadrillage qui contient 4
    		// boutons d'opération – Plus, Moins, Diviser, Multiplier
    		JPanel panneauOpérations = new JPanel();
    		GridLayout dispositionOpérations = new GridLayout(4, 1);
    		panneauOpérations.setLayout(dispositionOpérations);
    		panneauOpérations.add(boutonPlus);
    		panneauOpérations.add(boutonMoins);
    		panneauOpérations.add(boutonMultiplier);
    		panneauOpérations.add(boutonDiviser);
    		// Ajoute le panneau des opérations à la zone est
    		// de la fenêtre
    		contenuFenêtre.add("East", panneauOpérations);
    		// Crée le cadre et lui affecte son contenu
    		JFrame frame = new JFrame("Calculatrice");
    		frame.setContentPane(contenuFenêtre);
    		// Affecte à la fenêtre des dimensions suffisantes pour
    		// prendre en compte tous les contrôles
    		frame.pack();
    		// Affiche la fenêtre
    		frame.setVisible(true);
    		// Instancie le récepteur d'événements et l'enregistre
    		// auprès de chaque bouton
    		MoteurCalcul moteurCalcul = new MoteurCalcul(this);
    		bouton0.addActionListener(moteurCalcul);
    		bouton1.addActionListener(moteurCalcul);
    		bouton2.addActionListener(moteurCalcul);
    		bouton3.addActionListener(moteurCalcul);
    		bouton4.addActionListener(moteurCalcul);
    		bouton5.addActionListener(moteurCalcul);
    		bouton6.addActionListener(moteurCalcul);
    		bouton7.addActionListener(moteurCalcul);
    		bouton8.addActionListener(moteurCalcul);
    		bouton9.addActionListener(moteurCalcul);
    		boutonVirgule.addActionListener(moteurCalcul);
    		boutonPlus.addActionListener(moteurCalcul);
    		boutonMoins.addActionListener(moteurCalcul);
    		boutonDiviser.addActionListener(moteurCalcul);
    		boutonMultiplier.addActionListener(moteurCalcul);
    		boutonEgale.addActionListener(moteurCalcul);
    	}
    	public static void main(String[] args) {
    		// Instancie la classe Calculatrice
    		Calculatrice calc = new Calculatrice();
    	}
    }
    
     
  • Créer jeu puissance 4 en java

    admin 22 h 31 min on 7 octobre 2009 | 0 Permalink | Reply
    Tags: application, , jeux java

    Jeu puissance 4 : application java avec interface graphique :

    Le jeu puissance 4 est un jeu bien connue qui permet à deux utilisateurs de placer des jetons dans une grille prévue à cette effet, afin d’aligner quatre jetons de la même couleur pour remporter la partie.
    Voici une image du résultat de la réalisation de cette application :

    puissance4-1024x640.jpg

    Dans cette application, il s’agit uniquement de permettre à 2 joueurs de s’affronter l’un contre l’autre. Il n’y a aucune intelligence artificielle implémentée. Il n’est donc pas possible de jouer contre un « ordinateur ».

    Réalisation d’une application Java qui représente le célèbre jeu puissance4

    Pour réaliser cette application, il est nécessaire de télécharger les images de l’interface graphique du jeu puissance 4.

    Cette application est réalisée à l’aide de quatre classes. La classe Main, la classe modèle, la classe contrôleur et la classe vue. Cette application peut être réalisée de différentes manières, selon le modèle de développement choisi. Dans ce mini tutoriel, on fait le choix de choisir le modèle mvc.

    Liens vers la page Créer application puissance 4

     
c
compose new post
j
next post/next comment
k
previous post/previous comment
r
reply
e
edit
o
show/hide comments
t
go to top
esc
cancel