Un cube en 3d qui tourne dans tous les sens (code pour gcc)

Soyez le premier à donner votre avis sur cette source.

Vue 7 503 fois - Téléchargée 366 fois

Description

C'est un super cube en 3D qui tourne sur tous les axes, plutôt jolie.

Le code est compilé avec gcc v2.8.0 pour djgpp v2. Vous pouvez télécharger les fichier nécessaire à l'installation du compilateur et de djgpp sur mon site en cas de problème (section programmation \ C/C++ \ les bases \ editeurs / compilateurs).

Source / Exemple :


#include<bios.h> 
#include<math.h>
#include<stdlib.h> 
#include<sys/nearptr.h> 

char *ecran; //pointeur sur mémoire vidéo
char *virtuel; //pointeur sur l'écran virtuel

/////////////////////////////////////////////////////
//	Initialisation du mode vga	//
/////////////////////////////////////////////////////

int init_vga_mode(void)
{
union REGS regs;
__djgpp_nearptr_enable();
ecran=(char *)(0xA0000 + __djgpp_conventional_base);
if((virtuel=(char *)malloc(320*200))==NULL)
{
return(1);
}
regs.h.ah=0x00;
regs.h.al=0x13;
int86(0x10,&regs,&regs);
return(0);
} 

//////////////////////////////  
//    Affichage d'un pixel //
//////////////////////////////

void putpixel(int x, int y, int color)
{
virtuel[(y*320)+x]=color;
}

/////////////////////////////////////////////////////////////////////////
//Copie la mémoire de l'écran virtuel dans la mémoire vidéo //
///////////////////////////////////////////////////////////////////////

void copyecran()
{
	memcpy(ecran,virtuel,64000);
}

///////////////////////////////////////////////////////////////////
//	Vide la mémoire de l'écran virtuel	//
/////////////////////////////////////////////////////////////////

void effacecran()
{
	memset(virtuel,0,64000);
}

///////////////////////////////////////////////////////////////////
//	Attente du retour du faisceau verticale	//
/////////////////////////////////////////////////////////////////

void verticale()
{
	while   (inp(0x3DA) & 8);
  while (!(inp(0x3DA) & 8));

}

////////////////////////////////
//      Fonction cube         //
///////////////////////////////

void cube(void)
{
	double  x1, y1, z, x, y, x2, y2, z2, x3, y3, z3, x4, y4, z4;
	int i;
	double a, j;

	int pointx[8]={100,100,100,100,-100,-100,-100,-100};
	int pointy[8]={100,-100,-100,100,-100,100,100,-100};
	int pointz[8]={-100,-100,100,100,-100,-100,100,100};

	while(!kbhit())		//tend qu'aucune touche n'est saisie
	{
for(j=0; j<=360; j+=1)
{
	effacecran();
	a = (M_PI*j)/(180);
	for(i=0; i<8; i++)
	{
	x = pointx[i];
	y = pointy[i];
	z = pointz[i];

	/////////////////////////////////////////////////////
	//  calcul de rotation des points en 3D	//
	////////////////////////////////////////////////////

	x2= z*sin(a)+x*cos(a);
	z2= z*cos(a)-x*sin(a);
	
	y3= y*cos(a)-z2*sin(a);
	z3= y*sin(a)+z2*cos(a);

	x4= y3*sin(a)+x2*cos(a);
	y4= y3*cos(a)-x2*sin(a);

	/////////////////////////////////////////////////////
	//	Projection des points 3D en 2D	//
	////////////////////////////////////////////////////

	x1 = 160 + (256*x4)/(640+z3);
                y1 = 100 - (256*y4)/(640+z3);

	putpixel(x1,y1,11);
	}
	verticale();	//Attend le retour du faisceau vertical
	copyecran();	//Affiche la scène
}
}
}

main(void)
{
	init_vga_mode();
	cube();

}

Conclusion :


Je vais expliquer un peu le fonctionnement du code.
La fonction init_vga_mode installe le mode vga 13h.
putpixel() :Afficheun pixel à l'écran, ici putpixel stocke un pixel dans l'écran virtuel, si vous voulez afficher directement le pixel à l'écran remplacez virtuel par ecran dans la fonction.
copyecran : utile car l'on a stocké nos données dans l'écran virtuel, il faut les faire passer sur le vrai écran pour afficher la scène.
effacecran : rien à dire, on comprend bien.
verticale(): permet d'éviter les effets de neige et les scintillements.
cube(): Pour réaliser le cube on initialise tous les sommets grâce aux trois tableaux.
Ensuite on utilise les bonnes vielles formules de math pour faire tourner les points.
Puis enfin on transforme les points 3D en 2D grâce a une projection.

Bon c'est pas trop simple à expliquer en quelques lignes, surtout si vous n'avez jamais fais de programmation graphique.
Si vous êtes débutant et que vous souhaitez apprendre les bases de la programmation graphique demandez moi des cours sur mon site, ça me motivera :-).

Codes Sources

A voir également

Ajouter un commentaire

Commentaires

cs_bouba
Messages postés
518
Date d'inscription
dimanche 2 décembre 2001
Statut
Membre
Dernière intervention
10 novembre 2007
3 -
Salut, bon, ça fais super longtemps que je n'ai pas regardé tout ça. Avec un peu de recherche je me suis effectivement rendu compte que ce code ne pouvait pas fonctionner sous Windows XP/NT/2000/2003 et Vista. Apparemment ça viendrait du fait que les appelles d'interruptions directes (en l'occurrence l'interruption 13h dans ce programme) ne soient plus possibles (car Windows fonctionne maintenant en mode protégé). J'ai lu quelques articles disant qu'il était possible d'utiliser une astuce avec les Rings. Un ring est un mode d'exécution, le ring0 est le plus permissif, c'est dans ce mode que sont exécutées les fonctions noyaux bas niveau, les ring1 et ring2 ne sont pas utilisées sous Windows. Le ring3 est le mode utilisé pour les programmes classiques. Et donc, pour pouvoir appeler les INTs (sous Windows XP/NT/2000/2003) il faut être en ring0, mode administrateur. Mais apparemment il n'est pas conseillé d'être dans ce mode plus de 10s car après le noyau Windows ne sait plus ou donner de la tête.

Bon, je ne sais pas si j'ai bien tout pigé, vous pourrez trouver plus d'informations ici: http://www.asmfr.com/code.aspx?ID=15343

Si quelqu'un pouvait nous éclairer sur le sujet ce serait sympa.

En tout cas merci à tout ceux qui ont posté des commentaires sur cette source.

++

Bouba
sieuzac
Messages postés
3
Date d'inscription
mardi 19 juillet 2005
Statut
Membre
Dernière intervention
30 mai 2007
-
Salut
Moi aussi l'exe ne se lance pas. Sa fais quelque moi que j'aiser de faire une biblio grafique. Pour sela je m'inspir de code dons pratiquement aucun ne fonction. Je suis sur XP et il se peux que se fameux Bilgaite est temter de bloquer les acser memoir. En effet si nous faisont des aisser sur 98 les code tourne. Il ne me meque plus ca faire des aiser sur linux. Voila j'ai temter de deverser se broulli. Si quellequn pourez m'eclairé je lui serai reconaissent. ++
cs_sim38
Messages postés
9
Date d'inscription
samedi 4 novembre 2006
Statut
Membre
Dernière intervention
20 novembre 2008
-
Salut
Moi non plus je n'arrive pas a faire fonctonner l'application. il n'y a rien qui s'affiche...
douggyfresh
Messages postés
21
Date d'inscription
lundi 24 mai 2004
Statut
Membre
Dernière intervention
25 mai 2005
-
mon pote, j'ai telecharge le zip. Ton code source ne se compile avec mon compil' qu'est Borland 5.01. De plus, l'exe que tu fournis avec la source ne marche non plus.
Apportes-y un peu de correction. Ensuite j'y pourrai faire de commentaires.
cs_bouba
Messages postés
518
Date d'inscription
dimanche 2 décembre 2001
Statut
Membre
Dernière intervention
10 novembre 2007
3 -
Bien sûr qu'il doit être possible de l'adapter a dev-C++, tout est possible! J'ai essayé de le faire mais je me suis confronté à un problème qui est sans doute le même qu'avec Visual C++ et qui est sans doute générale pour tout les compilo 32 bits. Le mode VGA plante! La solution est peut être d'utiliser l'assembleur AT&T avec Dev C++ mais je ne suis même pas sûr que celà marchera car j'ai testé ceci sous linux et ca plante aussi. Si tu trouve une solution pour résoudre ce problème merci de me répondre.
Alé, a+.
Bouba

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.