Calculatrices
Graph 35 à 100 (CFX)
Graph 25/25+ (Pro) (fx-7400)
Graph 75/85/95 (SD) (fx-9860)
Graph 100/100+ (AFX)
ClassPad 300/330
Fx-CG 10/20
Fx-CP 400
Graph 90+E

Retour aux miniatures
Tri avancé
Liste des programmes
Nom Date
Tamacasio
Zork
Essai
Dungeon
MarioMaker
15 second ninja
Run
Slide
Arena
Tu Quoque
Kirby DreamLand
Geometry Dash
KT Polar Bear
Pac-Man
Feeries
IPod Spin
SeaRush
Atlantis
L'invasion Sean
Smiley
Pages: 1,2,3,4,5,6,7,8,9 >>

¤ Transférer un programme sur
sa calculatrice

¤ Vous cherchez une fonction ?
Jeux >> Graphs 75/85/95 (SD) >> Add-ins >> Essai
Essai
Version : 0 Taille : 23000 octets Ajouté le : 2018-08-03 14:07 Modifié le : 2018-09-09 17:51
Auteur et posteur :
Shadow15510
Hors ligne
Rédacteur
Points: 1742
Défis: 15
Message
Planète Casio - Add-in Casio - Essai - shadow15510 - Calculatrices
Nombre de visites sur cette page : 738
Score au progrank : 19
Pas encore de note !

Vous devez être inscrit(e) et avoir 20 points ou plus pour noter.
67 téléchargements | Soumettre un test


A cause du changement de processeur des nouvelles Graph 35+ USB, 75 et 95 SD, de nombreux addins sont incompatibles avec ces calculatrices.
Rendre un addin compatible - Plus d'informations sur ce problème - Liste des addins compatibles

Description :

Mon premier jet en C... Ce n'est pas brillant mais faut ben commencer...
On peut juste bouger le personnage à l'aide des flèches. Les collisions sont gérée et je travaille sur "comment rentrer dans la petite maisons ??"
L'arbre est issu d'une banque de sprite que j'ai trouvé sur ce site. Et la maisons est constituées de tileset que j'ai faite grâce à un tuto (sur ce site également)
Le premier fichier (*.g1a) est le "jeu" le deuxième correspond au sources.

Mon personnage est animé lors des déplacements

Améliorations à venir
peut-être...

-Possibilité d'entrer dans le bâtiment.⇒Fait
-Gestion de la course par la pression d'une touche du Replay et de Shift.
-gestion de l'intérieur du bâtiment
-nouveau style de maisons en brique
-système d'énigme, interrupteur, histoire,...
-armes, et système de combat
-map plus évoluées : herbes, cailloux, d'autres arbres et artéfacts


Commentaires :

Pages: 1, 2, 3, 4, 5, 6, 7, 8 | Suivante

Lightmare
Hors ligne
Membre de CreativeCalc
Points: 280
Défis: 0
Message
Posté le 05-08-2018 à 21:35 | #
Salut Shadow ! C'est génial que des gens se mettent encore à programmer des add-ins !

... Une p'tite image ?
Shadow15510
Hors ligne
Rédacteur
Points: 1742
Défis: 15
Message
Posté le 09-08-2018 à 20:41 | #
J'essayerai d'en mettre une
Mais sincèrement ce n'est pas un jeu c'est tout juste un début de commencement de gestion de graphismes avec le C...
Cela ne vaut pas la peine d'être téléchargé... Par contre toute aide sur le code sera la bienvenue : gestion des chocs, affichages,...etc
Ce petit bout de code marche parce que le bon dieux l'veut bien... et je crains qu'une map plus complexe ne soit pas aussi fluide...
Redeyes
Hors ligne
Membre
Points: 220
Défis: 1
Message
Posté le 09-08-2018 à 20:48 | #
C'est impressionant déja pour un début! en C? Il y a plus de possibilités que le basic ? En tout cas j'aime beaucoup tes graphismes
Shadow15510
Hors ligne
Rédacteur
Points: 1742
Défis: 15
Message
Posté le 09-08-2018 à 20:51 | #
merci
Pour les graphismes je n'ai pas fait grand-choses. Pour les capacités, c'est... énormes j'en suis rester sur le cul quand j'ai vu la vitesse d'exécution !!
En BASIC Casio un boucle For (vide) qui va de 0 à 75 à un impact visible en C il faut pousser la boule For (vide) de 0 à 20 000 pour avoir un truc visible
Redeyes
Hors ligne
Membre
Points: 220
Défis: 1
Message
Posté le 09-08-2018 à 20:52 | #
Ca fait rêver, franchement!
Drak
Hors ligne
Rédacteur
Points: 1744
Défis: 38
Message
Posté le 09-08-2018 à 21:58 | #
Disons plutôt que le Basic est très lent !
Shadow15510
Hors ligne
Rédacteur
Points: 1742
Défis: 15
Message
Posté le 11-08-2018 à 17:03 | #
C'est bon : y a des images
Lephenixnoir
Hors ligne
Administrateur
Points: 12512
Défis: 136
Message
Posté le 12-08-2018 à 20:50 | #
Eh bien ! J'ai pas pu m'empêcher de le télécharger quand j'ai vu l'image

Tu voulais des commentaires sur le code, eh bien en voilà !

-

Quand tu as des variables qui vont dans la mémoire, il y a deux destinations possibles : la ROM (mémoire de stockage) et la RAM (mémoire de calcul). La ROM, tu peux lire ce qui est dedans mais tu ne peux pas modifier les valeurs. La RAM, tu peux lire et écrire à volonté dedans.

Pour les gros paquets de données qui ne changent jamais, comme les sprites, on préfère utiliser la ROM parce que la RAM est petite et précieuse. En déclarant le sprite avec const char truc[] = { ... } au lieu de char truc[] = { ... } (note le const), on indique au compilateur que les données ne vont jamais changer, et cela l'incite à mettre le tableau dans la ROM. C'est mieux.

-

Quand tu dessines à l'écran dans un add-in, la technique c'est :
1. Tu dessines tout dans la VRAM sans changer ce qu'il y a à l'écran
2. Tu envoies la VRAM à l'écran (quasi-instantané)

La VRAM, c'est juste une zone de RAM assez grande pour qu'on puisse représenter tous les pixels de l'écran dedans.

Cette technique s'appelle double-buffering (parce qu'il y a deux "écrans" ou "buffers" : le vrai et la VRAM), et son intérêt c'est que ton utilisateur ne voit pas ce que tu es en train de dessiner, puisque tu le fais dans la VRAM. Il ne voit que le résultat final, et le résultat est plus fluide.

Tout ça pour dire qu'en général, on n'utilise jamais de fonctions pour dessiner directement à l'écran, en particulier par de ML_clear_screen(). Car au tout début de ton programme, à cause de cet appel de fonction, l'écran est blanc pendant une petite fraction de seconde. Si tu fais ça trop souvent, ça va donner l'impression de clignoter.

Morale : tu n'as pas besoin d'appeler ML_clear_screen() quand tu veux commencer à dessiner sur du blanc. ML_clear_vram() suffit.

-

À un endroit, tu as écrit ML_display_vram;, ce qui n'a aucun effet ! :o

Pour appeler la fonction, n'oublie pas les parenthèses, même s'il n'y a pas d'arguments : ML_display_vram().

Comment ça se fait que les contenus de la VRAM étaient quand même affichés à l'écran, alors ? Eh bien, c'est GetKey(), qui fait automatiquement un ML_display_vram (en gros) quand tu l'appelles

-

Le dernier point est un peu compliqué... je ne vais pas m'étendre trop dessus.

Tu as mélangé GetKey() et IsKeyDown(), c'est « mal ». On voit que tu as essayé, avec des Sleep(), de faire en sorte que le personnage continue de se déplacer tant que la touche reste appuyée.

Eh bien, en fait, tu n'as pas besoin ! GetKey() répète les touches directionnelles, c'est-à-dire que si tu restes appuyé sur une touche GetKey() va renvoyer plusieurs fois son numéro.

Voilà comment tu peux améliorer ta boucle while : en-dessous de chaque case, tu déplaces le personnage dans la direction indiquée, mais juste une fois. Tu ne cherches pas à savoir si la touche reste appuyée. Si tu fais ça, alors dans chaque case, il ne doit plus y avoir de IsKeyDown(), plus de Sleep, et plus de boucle while. C'est bon ?

Dans ce cas, quand j'appuierai sur [↓], GetKey() va renvoyer KEY_CTRL_DOWN et tu vas rentrer dans le switch. Mon personnage va descendre un peu, et hop, fini le switch. Ton programme va re-rentrer dans la boucle while et ré-appeler GetKey().

Et comme GetKey() répète les touches directionnelles, eh bien au bout d'un petit délai si la touche est toujours appuyée GetKey() va re-renvoyer KEY_CTRL_DOWN, et donc je vais continuer à descendre !

Je t'invite vraiment à faire cette modification que j'ai expliquée parce qu'actuellement la façon dont tu utilises le clavier est très bizarre et pas vraiment recommandable.

-

Voilà, j'en ai dit pas mal ! J'espère que ça te servira. Tu t'en sors très bien pour tes débuts, alors ne t'arrête surtout pas !
Drak
Hors ligne
Rédacteur
Points: 1744
Défis: 38
Message
Posté le 13-08-2018 à 16:58 | #
Super, c'est agréable de recevoir des conseils constructifs comme ça Je suis sûr que Shadow sera ravi.
Shadow15510
Hors ligne
Rédacteur
Points: 1742
Défis: 15
Message
Posté le 16-08-2018 à 17:59 | #
Je suis ravi effectivement
@Lephé : Merci des conseils et des encouragement

J'ai réussi à le faire entrer dans la maison !! via la touche alpha.
Je couche sur le papier un projet de Tomagoshi... Sans grand-espoir c'est juste pour le fun en plus y en a déjà un...

Pour toutes tes idées je rêverais mon code : parce que les commentaires constructifs c'est sympa mais si j'en fait rien c'est complètement con je te demanderais sans dote de petites précision le C me parait bien technique tout à coup...

Pages: 1, 2, 3, 4, 5, 6, 7, 8 | Suivante

Planète Casio v42 © créé par Neuronix et Muelsaco 2004 - 2018 | Il y a 28 connectés | Nous contacter | Qui sommes-nous ? | Licences et remerciements

Planète Casio est un site communautaire indépendant, géré bénévolement et n'est donc pas affilié à Casio | Toute reproduction de Planète Casio, même partielle, est interdite
Les fichiers, programmes et autres publications présents sur Planète Casio restent la propriété de leurs auteurs respectifs et peuvent être soumis à des licences ou des copyrights.
CASIO est une marque déposée par CASIO Computer Co., Ltd