Du pixelart sur vos écrans OLED/fr : Différence entre versions

(Mise à jour pour être en accord avec la nouvelle version de la source de la page)
(update property name)
 
Ligne 1 : Ligne 1 :
{{ {{tntn|Tuto Details}}
+
{{Tuto Details
 
|Main_Picture=Du_pixelart_sur_vos_écrans_OLED_pixelart_wiki.jpg
 
|Main_Picture=Du_pixelart_sur_vos_écrans_OLED_pixelart_wiki.jpg
 
|Licences=Attribution (CC BY)
 
|Licences=Attribution (CC BY)
Ligne 16 : Ligne 16 :
 
|IsTranslation=1
 
|IsTranslation=1
 
}}
 
}}
{{ {{tntn|Introduction}}
+
{{Introduction
 
|Introduction=Dessiner sur des écrans OLED ? Ça peut paraitre compliqué, mais avec un peu d'entrainement, on peut faire un paquet de choses comme son propre logo, voir de l'animation ou même des jeux vidéos !
 
|Introduction=Dessiner sur des écrans OLED ? Ça peut paraitre compliqué, mais avec un peu d'entrainement, on peut faire un paquet de choses comme son propre logo, voir de l'animation ou même des jeux vidéos !
 
}}
 
}}
{{ {{tntn|TutoVideo}}
+
{{TutoVideo
 
|VideoType=Youtube
 
|VideoType=Youtube
 
|VideoURLYoutube=https://www.youtube.com/watch?v=JfFld6lq_7o
 
|VideoURLYoutube=https://www.youtube.com/watch?v=JfFld6lq_7o
 
}}
 
}}
{{ {{tntn|Materials}}
+
{{Materials
 
|Step_Picture_00=Filtration_sur_sable_par_arduino_3.jpg
 
|Step_Picture_00=Filtration_sur_sable_par_arduino_3.jpg
 
|Step_Picture_01=Du_pixelart_sur_vos_écrans_OLED_0.91_I2C_OLED_128x32-_Blue_4-1000x750.png
 
|Step_Picture_01=Du_pixelart_sur_vos_écrans_OLED_0.91_I2C_OLED_128x32-_Blue_4-1000x750.png
Ligne 30 : Ligne 30 :
 
- Écran  OLED monochrome
 
- Écran  OLED monochrome
 
|Tools=
 
|Tools=
|ExternalAttachmentsLinks={{ {{tntn|ExternalAttachmentsLinks}}
+
|ExternalAttachmentsLinks={{ExternalAttachmentsLinks
 
|ExternalAttachmentsLinks=https://github.com/maditnerd/oled_xbm
 
|ExternalAttachmentsLinks=https://github.com/maditnerd/oled_xbm
}}{{ {{tntn|ExternalAttachmentsLinks}}
+
}}{{ExternalAttachmentsLinks
 
|ExternalAttachmentsLinks=https://create.arduino.cc/editor/madnerd/0a94bf35-ada8-4695-9f56-d62ea2ed4cff/preview
 
|ExternalAttachmentsLinks=https://create.arduino.cc/editor/madnerd/0a94bf35-ada8-4695-9f56-d62ea2ed4cff/preview
}}{{ {{tntn|ExternalAttachmentsLinks}}
+
}}{{ExternalAttachmentsLinks
 
|ExternalAttachmentsLinks=https://create.arduino.cc/editor/madnerd/f616433a-3f8a-483c-8ca2-6447dac0314c/preview
 
|ExternalAttachmentsLinks=https://create.arduino.cc/editor/madnerd/f616433a-3f8a-483c-8ca2-6447dac0314c/preview
}}{{ {{tntn|ExternalAttachmentsLinks}}
+
}}{{ExternalAttachmentsLinks
 
|ExternalAttachmentsLinks=https://create.arduino.cc/editor/madnerd/b4c53d85-5579-4953-89d4-29e0a3b4228c/preview
 
|ExternalAttachmentsLinks=https://create.arduino.cc/editor/madnerd/b4c53d85-5579-4953-89d4-29e0a3b4228c/preview
}}{{ {{tntn|ExternalAttachmentsLinks}}
+
}}{{ExternalAttachmentsLinks
 
|ExternalAttachmentsLinks=https://create.arduino.cc/editor/madnerd/7deed5b1-6f4d-4cd6-b662-0e2a88a93974/preview
 
|ExternalAttachmentsLinks=https://create.arduino.cc/editor/madnerd/7deed5b1-6f4d-4cd6-b662-0e2a88a93974/preview
 
}}
 
}}
 
}}
 
}}
{{ {{tntn|Separator}}}}
+
{{Separator}}
{{ {{tntn|Tuto Step}}
+
{{Tuto Step
 
|Step_Title=Choisir son image
 
|Step_Title=Choisir son image
 
|Step_Content=Nous allons utiliser un écran 128x32 (les écrans en 128x64 sont aussi très répandus si vous voulez plus d'espace), il nous faut donc choisir une '''petite image.'''
 
|Step_Content=Nous allons utiliser un écran 128x32 (les écrans en 128x64 sont aussi très répandus si vous voulez plus d'espace), il nous faut donc choisir une '''petite image.'''
Ligne 52 : Ligne 52 :
 
|Step_Picture_00=Du_pixelart_sur_vos_écrans_OLED_112885.png
 
|Step_Picture_00=Du_pixelart_sur_vos_écrans_OLED_112885.png
 
}}
 
}}
{{ {{tntn|Tuto Step}}
+
{{Tuto Step
 
|Step_Title=Convertir son image en pixel art
 
|Step_Title=Convertir son image en pixel art
 
|Step_Content={{Info|Tout le code est disponible sur github à cette adresse : https://github.com/maditnerd/oled_xbm}}
 
|Step_Content={{Info|Tout le code est disponible sur github à cette adresse : https://github.com/maditnerd/oled_xbm}}
Ligne 77 : Ligne 77 :
 
|Step_Picture_02=Du_pixelart_sur_vos_écrans_OLED_brush.png
 
|Step_Picture_02=Du_pixelart_sur_vos_écrans_OLED_brush.png
 
}}
 
}}
{{ {{tntn|Tuto Step}}
+
{{Tuto Step
 
|Step_Title=Convertir son pixel art en code arduino
 
|Step_Title=Convertir son pixel art en code arduino
 
|Step_Content=Sauvegarder votre image au format XBM
 
|Step_Content=Sauvegarder votre image au format XBM
Ligne 98 : Ligne 98 :
 
  };
 
  };
 
}}
 
}}
{{ {{tntn|Tuto Step}}
+
{{Tuto Step
 
|Step_Title=Afficher votre image
 
|Step_Title=Afficher votre image
 
|Step_Content={{Idea|Je vous conseille de garder le code du logo dans un fichier .h, ainsi il sera plus simple de lire votre code}}
 
|Step_Content={{Idea|Je vous conseille de garder le code du logo dans un fichier .h, ainsi il sera plus simple de lire votre code}}
Ligne 130 : Ligne 130 :
 
|Step_Picture_01=Du_pixelart_sur_vos_écrans_OLED_hackter_logo.jpg
 
|Step_Picture_01=Du_pixelart_sur_vos_écrans_OLED_hackter_logo.jpg
 
}}
 
}}
{{ {{tntn|Tuto Step}}
+
{{Tuto Step
 
|Step_Title=Animation - Position
 
|Step_Title=Animation - Position
 
|Step_Content=Pour cette partie nous allons utiliser le boulet de cannon de Super Mario Bros.
 
|Step_Content=Pour cette partie nous allons utiliser le boulet de cannon de Super Mario Bros.
Ligne 174 : Ligne 174 :
 
|Step_Picture_03=Du_pixelart_sur_vos_écrans_OLED_mariocann.jpg
 
|Step_Picture_03=Du_pixelart_sur_vos_écrans_OLED_mariocann.jpg
 
}}
 
}}
{{ {{tntn|Tuto Step}}
+
{{Tuto Step
 
|Step_Title=Animation - Images multiples
 
|Step_Title=Animation - Images multiples
 
|Step_Content=Une autre façon d'animer une image et d'utiliser plusieurs images.
 
|Step_Content=Une autre façon d'animer une image et d'utiliser plusieurs images.
Ligne 220 : Ligne 220 :
 
|Step_Picture_00=Du_pixelart_sur_vos_écrans_OLED_hackster_anim.png
 
|Step_Picture_00=Du_pixelart_sur_vos_écrans_OLED_hackster_anim.png
 
}}
 
}}
{{ {{tntn|Notes}}
+
{{Notes
 
|Notes=Si vous voulez être informés des prochains tutoriels suivez moi sur twitter : https://twitter.com/m4dnerd
 
|Notes=Si vous voulez être informés des prochains tutoriels suivez moi sur twitter : https://twitter.com/m4dnerd
 
}}
 
}}
{{ {{tntn|Tuto Status}}
+
{{Tuto Status
 
|Complete=Published
 
|Complete=Published
 
}}
 
}}

Version actuelle datée du 9 décembre 2019 à 11:31

Auteur avatarRémi Sarrailh (µsini) | Dernière modification 9/12/2019 par Clementflipo

Du pixelart sur vos écrans OLED pixelart wiki.jpg
Le pixel art c'est cool ! si vous voulez le rendre encore plus rétro quoi de mieux qu'un petit écran OLED. Nous allons voir comment créer nos propres images et les animer.

Introduction

Dessiner sur des écrans OLED ? Ça peut paraitre compliqué, mais avec un peu d'entrainement, on peut faire un paquet de choses comme son propre logo, voir de l'animation ou même des jeux vidéos !

Video d'introduction

Étape 1 - Choisir son image

Nous allons utiliser un écran 128x32 (les écrans en 128x64 sont aussi très répandus si vous voulez plus d'espace), il nous faut donc choisir une petite image.

Les sprites de la GameBoy sont très faciles à convertir, mais gardez à l'esprit que nous sommes limités au noir et blanc, là ou la gameboy est capable d'afficher 4 nuances de gris.

Vous pouvez télécharger des sprites sur https://www.spriters-resource.com/ comme point de départ.




Étape 2 - Convertir son image en pixel art

Tout le code est disponible sur github à cette adresse : https://github.com/maditnerd/oled_xbm

Pour notre premier exemple, nous allons utiliser le logo d'hackster.io

Nous allons

  • Redimensionner l'image en 128x32
  • Redessiner l'image avec deux couleurs
  • La convertir en XBM (code arduino)
N'importe quel logiciel peut faire l'affaire, mais je recommande chaudement Krita : https://krita.org/en/

Redimensionner l'image à la taille la plus proche de votre écran (128x32) : Image --> Redimensionner l'image à une nouvelle taille

Puis augmenter la taille de votre canvas à 128x32 : Image --> Redimensionner le tableau

Dans les préréglages des brosses, choisissez Pixel Art

Puis redessiner l'image.

Appuyer sur X pour passer d'une couleur à l'autre.


Étape 3 - Convertir son pixel art en code arduino

Sauvegarder votre image au format XBM

Sauvegarder le aussi au format PNG, vous ne pourrez pas modifier votre fichier XBM avec Krita !

Ouvrez le fichier XBM avec un éditeur de texte et changez le nom des variables

Fichier XBM

#define _width 128
#define _height 32
static char _bits[] = {
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00... 
};

Fichier logo.h

#define logo_width 128
#define logo_height 32
static const unsigned char logo[] U8X8_PROGMEM = {
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00... 
};

Étape 4 - Afficher votre image

Je vous conseille de garder le code du logo dans un fichier .h, ainsi il sera plus simple de lire votre code

Nous allons utiliser la bibliothèque U8g2 (elle est compatible avec beaucoup d'écrans)

#include <Wire.h> //I2C
#include <U8g2lib.h>
#include "logo.h"

//I2C SSD1306 128x32 (search U8g2 examples for other display)
U8G2_SSD1306_128X32_UNIVISION_F_HW_I2C u8g2(U8G2_R0, U8X8_PIN_NONE);

void setup() {
 u8g2.begin(); //Start Screen
 drawLogo();
}

void loop() {
}

void drawLogo() {
 u8g2.firstPage();
 do {
   u8g2.drawXBMP(0, 0, logo_width, logo_height, logo);
 } while ( u8g2.nextPage() );
}

J'ai aussi mis les fichiers PNG et XBM dans un dossier res/ dans mon code afin de savoir ce qu'il y a dans logo.h et de pouvoir le modifier ultérieurement.

Téléversez votre code et voilà !



Étape 5 - Animation - Position


Étape 6 - Animation - Images multiples

Une autre façon d'animer une image et d'utiliser plusieurs images.

Au lieu de changer la position X, nous allons utiliser une condition SWITCH et augmenter la valeur animation_state.

void drawAnimation() {
 u8g2.firstPage();
 do {
   switch (animation_state) {
     case 0:
       u8g2.drawXBMP(0, 0, logo_width, logo_height, logo_1);
       break;
     case 1:
       u8g2.drawXBMP(0, 0, logo_width, logo_height, logo_2);
       break;
     case 2:
       u8g2.drawXBMP(0, 0, logo_width, logo_height, logo_3);
       break;
     case 3:
       u8g2.drawXBMP(0, 0, logo_width, logo_height, logo_4);
       break;
     case 4:
       u8g2.drawXBMP(0, 0, logo_width, logo_height, logo_5);
       break;
     case 5:
       u8g2.drawXBMP(0, 0, logo_width, logo_height, logo_6);
       break;
   }
 } while ( u8g2.nextPage() );
}

Afin que notre animation soit complète, il nous faut l'inverser, pour cela, nous allons utiliser le booléen (vrai/faux) animation_direction afin que l'animation aille dans le sens inverse.

drawAnimation();
   if (animation_direction) {
     animation_state--;
   } else {
     animation_state++;
   }
   if (animation_state == 5) {
     animation_direction = true;
   }
   if (animation_state == 0) {
     animation_direction = false;
   }

Si on combine les deux techniques, on peut créer des animations plus complexe : https://www.youtube.com/watch?v=iB52FujIK-A




Notes et références

Si vous voulez être informés des prochains tutoriels suivez moi sur twitter : https://twitter.com/m4dnerd

Commentaires

Published