Ligne 1 : | Ligne 1 : | ||
{{ {{tntn|Tuto Details}} | {{ {{tntn|Tuto Details}} | ||
+ | |SourceLanguage=none | ||
+ | |Language=fr | ||
+ | |IsTranslation=0 | ||
|Main_Picture=Du_pixelart_sur_vos_écrans_OLED_P1120656.JPG | |Main_Picture=Du_pixelart_sur_vos_écrans_OLED_P1120656.JPG | ||
|Licences=Attribution (CC BY) | |Licences=Attribution (CC BY) | ||
− | |Description=Le pixel art c'est cool ! si vous voulez le rendre encore plus | + | |Description=<translate>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. | + | Nous allons voir comment créer nos propres images et les animer.</translate> |
|Area=Art, Electronics, Play and Hobbies | |Area=Art, Electronics, Play and Hobbies | ||
|Type=Technique | |Type=Technique | ||
Ligne 12 : | Ligne 15 : | ||
|Currency=EUR (€) | |Currency=EUR (€) | ||
|Tags=arduino, esp8266, esp32, oled, u8g2, pixel, pixelart | |Tags=arduino, esp8266, esp32, oled, u8g2, pixel, pixelart | ||
− | |||
− | |||
− | |||
}} | }} | ||
{{ {{tntn|Introduction}} | {{ {{tntn|Introduction}} | ||
− | |Introduction=Dessiner sur des écrans OLED ? | + | |Introduction=<translate>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 !</translate> |
}} | }} | ||
{{ {{tntn|TutoVideo}} | {{ {{tntn|TutoVideo}} | ||
Ligne 26 : | Ligne 26 : | ||
|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 | ||
− | |Material=- Microcontrôleur compatible avec u8g2 (arduino / esp8266 / esp32 etc...) | + | |Material=<translate>- Microcontrôleur compatible avec u8g2 (arduino / esp8266 / esp32 etc...) |
− | - | + | - Écran OLED monochrome</translate> |
− | |Tools= | + | |Tools=<translate></translate> |
|ExternalAttachmentsLinks={{ {{tntn|ExternalAttachmentsLinks}} | |ExternalAttachmentsLinks={{ {{tntn|ExternalAttachmentsLinks}} | ||
|ExternalAttachmentsLinks=https://github.com/maditnerd/oled_xbm | |ExternalAttachmentsLinks=https://github.com/maditnerd/oled_xbm | ||
Ligne 44 : | Ligne 44 : | ||
{{ {{tntn|Separator}}}} | {{ {{tntn|Separator}}}} | ||
{{ {{tntn|Tuto Step}} | {{ {{tntn|Tuto Step}} | ||
− | |Step_Title=Choisir son image | + | |Step_Title=<translate>Choisir son image</translate> |
− | |Step_Content=Nous allons utiliser un écran 128x32 (les écrans en 128x64 sont aussi très | + | |Step_Content=<translate>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 | + | 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. | + | Vous pouvez télécharger des sprites sur https://www.spriters-resource.com/ comme point de départ.</translate> |
+ | |Step_Picture_00=Du_pixelart_sur_vos_écrans_OLED_112885.png | ||
}} | }} | ||
{{ {{tntn|Tuto Step}} | {{ {{tntn|Tuto Step}} | ||
− | |Step_Title=Convertir son image en pixel art | + | |Step_Title=<translate>Convertir son image en pixel art</translate> |
− | |Step_Content=Pour notre premier exemple, nous allons utiliser le logo d'hackster.io | + | |Step_Content=<translate>Pour notre premier exemple, nous allons utiliser le logo d'hackster.io |
Nous allons | Nous allons | ||
* Redimensionner l'image en 128x32 | * Redimensionner l'image en 128x32 | ||
* Redessiner l'image avec deux couleurs | * Redessiner l'image avec deux couleurs | ||
− | * La convertir en XBM ( | + | * La convertir en XBM (code arduino) |
{{Idea|N'importe quel logiciel peut faire l'affaire, mais je recommande chaudement Krita : https://krita.org/en/}} | {{Idea|N'importe quel logiciel peut faire l'affaire, mais je recommande chaudement Krita : https://krita.org/en/}} | ||
− | Redimensionner l'image | + | 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''' | Puis augmenter la taille de votre canvas à 128x32 : Image --> '''Redimensionner le tableau''' | ||
− | Dans les préréglages des brosses, | + | Dans les préréglages des brosses, choisissez Pixel Art |
Puis redessiner l'image. | Puis redessiner l'image. | ||
− | {{Idea|Appuyer sur X pour passer d' | + | {{Idea|Appuyer sur X pour passer d'une couleur à l'autre.}}</translate> |
+ | |Step_Picture_00=Du_pixelart_sur_vos_écrans_OLED_hacksterio_logo_pixel.png | ||
+ | |Step_Picture_01=Du_pixelart_sur_vos_écrans_OLED_hackster.png | ||
+ | |Step_Picture_02=Du_pixelart_sur_vos_écrans_OLED_brush.png | ||
}} | }} | ||
{{ {{tntn|Tuto Step}} | {{ {{tntn|Tuto Step}} | ||
− | |Step_Title=Convertir | + | |Step_Title=<translate>Convertir son pixel art en code arduino</translate> |
− | |Step_Content=Sauvegarder votre image au format XBM | + | |Step_Content=<translate>Sauvegarder votre image au format XBM |
{{Warning|Sauvegarder le aussi au format PNG, vous ne pourrez pas modifier votre fichier XBM avec Krita !}} | {{Warning|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 | + | Ouvrez le fichier XBM avec un éditeur de texte et changez le nom des variables |
Fichier XBM | Fichier XBM | ||
Ligne 90 : | Ligne 94 : | ||
static const unsigned char logo[] U8X8_PROGMEM = { | static const unsigned char logo[] U8X8_PROGMEM = { | ||
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00... | 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00... | ||
− | }; | + | };</translate> |
}} | }} | ||
{{ {{tntn|Tuto Step}} | {{ {{tntn|Tuto Step}} | ||
− | |Step_Title=Afficher votre image | + | |Step_Title=<translate>Afficher votre image</translate> |
− | |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=<translate>{{Idea|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) | Nous allons utiliser la bibliothèque U8g2 (elle est compatible avec beaucoup d'écrans) | ||
Ligne 120 : | Ligne 124 : | ||
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. | 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à !</translate> | |
+ | |Step_Picture_00=Du_pixelart_sur_vos_écrans_OLED_res.png | ||
+ | |Step_Picture_01=Du_pixelart_sur_vos_écrans_OLED_hackter_logo.jpg | ||
}} | }} | ||
{{ {{tntn|Tuto Step}} | {{ {{tntn|Tuto Step}} | ||
− | |Step_Title=Animation - Position | + | |Step_Title=<translate>Animation - Position</translate> |
− | |Step_Content=Pour cette partie nous allons utiliser le boulet de cannon de Super Mario Bros. | + | |Step_Content=<translate>Pour cette partie nous allons utiliser le boulet de cannon de Super Mario Bros. |
Il est possible d'animer votre pixel art de deux façons : | Il est possible d'animer votre pixel art de deux façons : | ||
Ligne 131 : | Ligne 137 : | ||
Donc si nous voulons déplacer une image de gauche à droite, il suffit juste de changer la position X non ? | Donc si nous voulons déplacer une image de gauche à droite, il suffit juste de changer la position X non ? | ||
− | Si vous | + | Si vous utilisez un Arduino Uno, ça va marcher, mais avec des cartes plus puissantes (comme l'ESP8266) votre animation '''va aller beaucoup trop vite!''' |
Nous avons besoin de limiter le taux de rafraichissement de notre animation, nous pourrions utiliser un delay mais nous ne pourrions plus faire d'autres choses en même temps. | Nous avons besoin de limiter le taux de rafraichissement de notre animation, nous pourrions utiliser un delay mais nous ne pourrions plus faire d'autres choses en même temps. | ||
Ligne 148 : | Ligne 154 : | ||
} | } | ||
} | } | ||
− | Un dernier point, si nous voulons que notre image | + | Un dernier point, si nous voulons que notre image sorte de l'écran à droite et apparaisse lentement à gauche, nous devons aller plus loin que la largeur maximale de l'écran (128) , plus exactement (128+36), 36 étant la largeur de notre image. |
− | Une fois l'image | + | Une fois l'image sortie de l'écran à droite, nous la faisons apparaitre à -36 afin de donner l'impression qu'elle apparait à gauche. |
void loop() { | void loop() { | ||
if (tick.isExpired()) { | if (tick.isExpired()) { | ||
Ligne 160 : | Ligne 166 : | ||
tick.repeat(); | tick.repeat(); | ||
} | } | ||
− | } | + | }</translate> |
+ | |Step_Picture_00=Du_pixelart_sur_vos_écrans_OLED_grid_cannon.png | ||
+ | |Step_Picture_01=Du_pixelart_sur_vos_écrans_OLED_P1120658.JPG | ||
+ | |Step_Picture_02=Du_pixelart_sur_vos_écrans_OLED_P1120654.JPG | ||
+ | |Step_Picture_03=Du_pixelart_sur_vos_écrans_OLED_mariocann.jpg | ||
}} | }} | ||
{{ {{tntn|Tuto Step}} | {{ {{tntn|Tuto Step}} | ||
− | |Step_Title=Animation - Images multiples | + | |Step_Title=<translate>Animation - Images multiples</translate> |
− | |Step_Content=Une autre façon d'animer une image et d'utiliser plusieurs images. | + | |Step_Content=<translate>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''' | + | Au lieu de changer la position X, nous allons utiliser une '''condition SWITCH''' et augmenter la valeur '''animation_state.''' |
void drawAnimation() { | void drawAnimation() { | ||
u8g2.firstPage(); | u8g2.firstPage(); | ||
Ligne 192 : | Ligne 202 : | ||
} while ( u8g2.nextPage() ); | } 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. | + | 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(); | drawAnimation(); | ||
if (animation_direction) { | if (animation_direction) { | ||
Ligne 205 : | Ligne 215 : | ||
animation_direction = false; | 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</translate> | ||
+ | |Step_Picture_00=Du_pixelart_sur_vos_écrans_OLED_hackster_anim.png | ||
}} | }} | ||
{{ {{tntn|Notes}} | {{ {{tntn|Notes}} | ||
− | |Notes= | + | |Notes=<translate>Si vous voulez être informés des prochains tutoriels suivez moi sur twitter : https://twitter.com/m4dnerd</translate> |
}} | }} | ||
{{ {{tntn|Tuto Status}} | {{ {{tntn|Tuto Status}} | ||
− | |Complete= | + | |Complete=Published |
}} | }} |
Auteur Rémi Sarrailh (µsini) | Dernière modification 9/12/2019 par Clementflipo
arduino, esp8266, esp32, oled, u8g2, pixel, pixelart Du_pixelart_sur_vos_écrans_OLED_P1120656.JPG fr none Technique 0
Youtube
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.
Pour notre premier exemple, nous allons utiliser le logo d'hackster.io
Nous allons
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.
Sauvegarder votre image au format XBM
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... };
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à !
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
Si vous voulez être informés des prochains tutoriels suivez moi sur twitter : https://twitter.com/m4dnerd
Published
Vous avez entré un nom de page invalide, avec un ou plusieurs caractères suivants :
< > @ ~ : * € £ ` + = / \ | [ ] { } ; ? #