Correction de quelaues bugs: attente fin clic, sauvegarde sous nux, désactivation de distcc ds le makefile, début de gestion clavier (pas encore ascii mais bas niveau)

git-svn-id: svn://pulkomandy.tk/GrafX2/trunk@48 416bcca6-2ee7-4201-b75f-2eb2f807beb1
This commit is contained in:
Adrien Destugues 2008-03-31 12:00:21 +00:00
parent 22eac2bb82
commit 86edb4d1fb
6 changed files with 5889 additions and 5913 deletions

View File

@ -1,4 +1,4 @@
CC = gcc
CC = powerpc-linux-gnu-gcc
COPT = -Wall -Os -c
LOPT = -lSDL -o grafx2

View File

@ -7,15 +7,6 @@
// Gestion du mode texte de départ (pour pouvoir y retourner en cas de problème
byte Recuperer_nb_lignes(void)
{
/*
mov ax,1130h
xor bh,bh
push es
int 10h
pop es
inc dl
mov [esp+28],dl
*/
puts("Recuperer_nb_lignes non implémenté!\n");
return 0;
}
@ -72,11 +63,13 @@ void Set_palette(T_Palette Palette)
void Attendre_fin_de_click(void)
{
do
{
SDL_PumpEvents();
}
while(SDL_GetMouseState(NULL, NULL)&SDL_BUTTON(1)); //On attend tant que le bouton est enfoncé (TODO: vérif clic droit aussi ?)
SDL_Event event;
//On attend que l'utilisateur relache la souris. Tous les autres évènements
//sont ignorés
while(SDL_PollEvent(&event) && event.type == SDL_MOUSEBUTTONUP);
//On indique à la gestion des E/S que le bouton est laché et on rend la main
Mouse_K=0;
INPUT_Nouveau_Mouse_K=0;
}
@ -104,12 +97,16 @@ void Effacer_image_courante_Stencil(byte Couleur, byte * Pochoir)
void Effacer_image_courante(byte Couleur)
// Effacer l'image courante avec une certaine couleur
{
puts("Effacer_image_courante non implémenté!\n");
memset(
Principal_Ecran ,
Couleur ,
Principal_Largeur_image * Principal_Hauteur_image
);
}
void Sensibilite_souris(word X,word Y)
{
puts("Sensibilite_souris non implémenté!\n");
puts("Sensibilite_souris non implémenté!");
}
void Get_input(void)
@ -135,47 +132,28 @@ void Get_input(void)
break;
case SDL_KEYDOWN:
//Appui sur une touche du clavier
puts("Get-Input: clavier pas géré !");
//On met le scancode dans Touche"
Touche = event.key.keysym.scancode;
//On ajoute aussi l'état des modifiers
#define ekkm event.key.keysym.mod
if (ekkm & (KMOD_LSHIFT | KMOD_RSHIFT)
{
Touche |= 0x0100;
}
if (ekkm & (KMOD_LCTRL | KMOD_RCTRL)
{
Touche |= 0x0200;
}
if (ekkm & (KMOD_LALT | KMOD_RALT)
{
Touche |= 0x0400;
}
//Cas particulier: déplacement du curseur avec haut bas gauche droite
//On doit interpréter ça comme un mvt de la souris
/*
; Sinon, appel à l'interruption pour connaître son scancode
mov ah,10h
int 16h
; AH = Scancode
; AL = Caractère ASCII
; On place le scan code dans la partie basse de [Touche]
mov byte ptr[Touche],ah
mov Touche_ASCII,al ; ... et le code ASCII dans Touche_ASCII
; Appel à l'interruption pour connaitre l'état des touches de contrôle
mov ah,02h
int 16h
; AL = Etat des touches de contrôle
; On oublie les informations sur Insert, CapsLock, NumLock et ScrollLock
and al,00001111b
; On associe les deux Shifts (2 bits de poids faible)
mov ah,al
and ah,00000001b
shr al,1
or al,ah
; On met le resultat dans la partie haute de [Touche]
mov byte ptr[Touche+1],al
; On gère le cas [Touche] est un déplacement du curseur
mov ax,Touche
; Test [Touche] = Emulation de MOUSE UP

22
files.c
View File

@ -17,35 +17,35 @@
#include "linux.h"
#define COULEUR_FICHIER_NORMAL CM_Clair // Couleur du texte pour une ligne de fichier non slectionn
#define COULEUR_REPERTOIRE_NORMAL CM_Fonce // Couleur du texte pour une ligne de rpertoire non slectionn
#define COULEUR_FOND_NORMAL CM_Noir // Couleur du fond pour une ligne non slectionne
#define COULEUR_FICHIER_SELECT CM_Blanc // Couleur du texte pour une ligne de fichier slectionne
#define COULEUR_REPERTOIRE_SELECT CM_Clair // Couleur du texte pour une ligne de reprtoire slectionne
#define COULEUR_FOND_SELECT CM_Fonce // Couleur du fond pour une ligne slectionne
#define COULEUR_FICHIER_NORMAL CM_Clair // Couleur du texte pour une ligne de fichier non sélectionné
#define COULEUR_REPERTOIRE_NORMAL CM_Fonce // Couleur du texte pour une ligne de répertoire non sélectionné
#define COULEUR_FOND_NORMAL CM_Noir // Couleur du fond pour une ligne non sélectionnée
#define COULEUR_FICHIER_SELECT CM_Blanc // Couleur du texte pour une ligne de fichier sélectionnée
#define COULEUR_REPERTOIRE_SELECT CM_Clair // Couleur du texte pour une ligne de repértoire sélectionnée
#define COULEUR_FOND_SELECT CM_Fonce // Couleur du fond pour une ligne sélectionnée
int Determiner_repertoire_courant(void)
// Modifie Principal_Repertoire_courant en y mettant sa nouvelle valeur (avec le nom du
// disque)
//
// Renvoie 1 s'il y a et une erreur d'accŠs
// Renvoie 1 s'il y a eu une erreur d'accès
{
return (getcwd(Principal_Repertoire_courant,256)==NULL);
}
int Repertoire_existe(char * Repertoire)
// Dtermine si un rpertoire pass en paramŠtre existe ou non dans le
// rpertoire courant.
// Détermine si un répertoire passé en paramètre existe ou non dans le
// répertoire courant.
{
DIR* Enreg; // Structure de lecture des lments
DIR* Enreg; // Structure de lecture des éléments
if (strcmp(Repertoire,"..")==0)
return 1;
else
{
// On va chercher si le rpertoire existe … l'aide d'un Opendir. S'il
// On va chercher si le répertoire existe à l'aide d'un Opendir. S'il
// renvoie NULL c'est que le répertoire n'est pas accessible...
Enreg=opendir(Repertoire);

BIN
gfx2.cfg

Binary file not shown.

View File

@ -320,8 +320,10 @@ void Nom_fichier_complet(char * Nom_du_fichier, byte Sauve_Colorix)
strcpy(Nom_du_fichier,Principal_Repertoire_fichier);
if (Nom_du_fichier[strlen(Nom_du_fichier)-1]!='\\')
strcat(Nom_du_fichier,"\\");
//On va ajouter un / à la fin du chemin s'il n'y est pas encore
//Attention sous windows il faut un \...
if (Nom_du_fichier[strlen(Nom_du_fichier)-1]!='/')
strcat(Nom_du_fichier,"/");
// Si on est en train de sauvegarder une image Colorix, on calcule son ext.
if (Sauve_Colorix)

View File

@ -98,7 +98,7 @@ void Ligne_verticale_XOR_SDL (word Pos_X,word Pos_Y,word Hauteur)
color=*(Ecran+Pos_X+i*Largeur_ecran);
*(Ecran+Pos_X+i*Largeur_ecran)=~color;
}
SDL_UpdateRect(Ecran_SDL,Pos_X,Pos_Y,0,Hauteur);
SDL_UpdateRect(Ecran_SDL,Pos_X,Pos_Y,1,Hauteur);
}
void Display_brush_Color_SDL (word Pos_X,word Pos_Y,word Decalage_X,word Decalage_Y,word Largeur,word Hauteur,byte Couleur_de_transparence,word Largeur_brosse)
@ -161,17 +161,13 @@ void Remap_screen_SDL (word Pos_X,word Pos_Y,word Largeur,word Hauteur,b
void Afficher_une_ligne_ecran_SDL (word Pos_X,word Pos_Y,word Largeur,byte * Ligne)
/* On affiche toute une ligne de pixels. Utilisé pour les textes. */
{
int i;
for(i=0;i<Largeur;i++)
{
Pixel_SDL(Pos_X+i,Pos_Y,*(Ligne+i));
}
memcpy(Ecran+Pos_X+Pos_Y*Largeur_ecran,Ligne,Largeur);
SDL_UpdateRect(Ecran_SDL,Pos_X,Pos_Y,Largeur,1);
}
void Lire_une_ligne_ecran_SDL (word Pos_X,word Pos_Y,word Largeur,byte * Ligne)
{
puts("Lire_une_ligne_ecran_SDL non implémenté!");
memcpy(Ligne,Largeur_ecran * Pos_Y + Pos_X + Ecran,Largeur);
}
void Afficher_partie_de_l_ecran_zoomee_SDL(word Largeur,word Hauteur,word Largeur_image,byte * Buffer)
@ -179,7 +175,7 @@ void Afficher_partie_de_l_ecran_zoomee_SDL(word Largeur,word Hauteur,word Largeu
puts("Afficher_partie_de_l_ecran_zoomee_SDL non implémenté!");
}
void Display_brush_Color_zoom_SDL(word Pos_X,word Pos_Y,word Decalage_X,word Decalage_Y,word Largeur,word Pos_Y_Fin,byte Couleur_de_transparence,word Largeur_brosse,byte * Buffer)
void Display_brush_Color_zoom_SDL (word Pos_X,word Pos_Y,word Decalage_X,word Decalage_Y,word Largeur,word Pos_Y_Fin,byte Couleur_de_transparence,word Largeur_brosse,byte * Buffer)
{
puts("Display_brush_Color_zoom_SDL non implémenté!");
}
@ -195,7 +191,7 @@ void Clear_brush_zoom_SDL (word Pos_X,word Pos_Y,word Decalage_X,word Dec
}
void Set_Mode_SDL()
/* On règle larésolution de l'écran */
/* On règle la résolution de l'écran */
{
Ecran_SDL=SDL_SetVideoMode(Largeur_ecran,Hauteur_ecran,8,SDL_HWSURFACE|SDL_FULLSCREEN);
Ecran=Ecran_SDL->pixels;