FORUM DE DISCUSSION SUR LE LANGAGE PANORAMIC

Développement d'applications avec le langage Panoramic
 
AccueilAccueil  FAQFAQ  RechercherRechercher  S'enregistrerS'enregistrer  MembresMembres  GroupesGroupes  Connexion  
Derniers sujets
» Compilateur FBPano
par jean_debord Aujourd'hui à 10:54

» demande pour recuperer un text speciale
par pascal10000 Hier à 22:04

» Casse-tête : Echanger les positions des cavaliers
par papydall Hier à 19:51

» KGF_dll - nouvelles versions
par Klaus Hier à 14:29

» Amélioration de la commande HINT
par papydall Mer 19 Juil 2017 - 3:30

» TEST SUR SHAPE
par papydall Mer 19 Juil 2017 - 1:17

» Un challenge à relever
par papydall Mar 18 Juil 2017 - 21:25

» Astuce : Indenter plusieurs lignes de code à la fois
par papydall Mar 18 Juil 2017 - 1:32

» Suggestion pour le forum
par papydall Lun 17 Juil 2017 - 20:28

» Truver les handles des onglets de Panoramic Editor
par Klaus Lun 17 Juil 2017 - 18:20

» Synedit_Editor - nouvelles versions
par Klaus Lun 17 Juil 2017 - 13:46

» Détermine si oui ou non un objet est PARENT d'un autre objet
par Klaus Dim 16 Juil 2017 - 11:58

» Une autre façon de terminer une application.
par papydall Dim 16 Juil 2017 - 3:53

» Déterminer le Handle de l’objet ayant le focus
par papydall Dim 16 Juil 2017 - 3:15

» Déterminer le HANDLE du Bureau
par papydall Dim 16 Juil 2017 - 1:59

Navigation
 Portail
 Index
 Membres
 Profil
 FAQ
 Rechercher
Rechercher
 
 

Résultats par :
 
Rechercher Recherche avancée
Juillet 2017
LunMarMerJeuVenSamDim
     12
3456789
10111213141516
17181920212223
24252627282930
31      
CalendrierCalendrier

Partagez | 
 

 1.98 du 28/2/2013: OpenBinaryFile et CloseBinaryFile

Voir le sujet précédent Voir le sujet suivant Aller en bas 
AuteurMessage
Klaus

avatar

Nombre de messages : 10062
Age : 68
Localisation : Ile de France
Date d'inscription : 29/12/2009

MessageSujet: 1.98 du 28/2/2013: OpenBinaryFile et CloseBinaryFile   Ven 1 Mar 2013 - 0:41

Nouvelle version:
KGF.dll V1.98 du 28/2/2013

Modules modifiée:
KGF.dll, KGF_SUB.bas

J'ai ajouté les fonctions OpenBinaryFile et CloseBinaryFile. A priori, le jeu de fonctions est complet, maintenant. Voici une doc provisoire de l'ensemble des fonctions:

Gestion des fichiers binaires

Les fichiers binaires sont identifiés par leur nom. Toutes les fonctions utilisent le nom complet
comme premier paramètre, pour identifier le fichier. Toutes ces fonctions sont indépendantes
les unes des autres. Chacune contient un traitement complet, y compris ouverture et fermeture
si cela est nécessaire.

Il y a deux fonctions spécifiques pour gérer les ouvertures et fermetures ce ces fichiers.
L'utilisation de ces fonctions est optionnelle et ne change en rien le fonctionnement des
autres routines, sur le plan fonctionnel. Mais elles ont une influence sur la performance.
En effet, si plusieurs fonctions d'accès au même fichier binaire doivent être effectuées,
il est utile de l'ouvrir avant la première fonction et de le fermer après la dernière fonction.
Ceci évite les ouvertures et fermetures implicites effectuées par chaque fonction. Les
fonctions de gestion des fichiers binaires sont réparties en 4 groupes:


1. Ouverture et fermeture

Ouverture d'un fichier binaire:
KGF.dll: res% = dll_call1("OpenBinaryFile",adr(nom$))
KGF_SUB.bas: OpenBinaryFile(nom$)

Cette fonction mémorise son nom et ouvre ce fichier de façon permanente, de sorte à être
accessible par les autres fonctions. L'utilisation de cette fonction est optionnelle.

Fermeture d'un fichier binaire:
KGF.dll: res% = dll_call1("CloseBinaryFile",adr(nom$))
KGF_SUB.bas: CloseBinaryFile(nom$)

Cette fonction ferme ce fichier de façon permanente s'il a été ouvert. L'utilisation de cette
fonction est optionnelle.


2. Etat d'un fichier

Retourner la taille d'un fichier bianire en octets
KGF.dll: res% = dll_call1("GetBinaryFileSize",adr(nom$))
KGF_SUB.bas: GetBinaryFileSize(nom$)

Cette fonction retourne le nombre d'octets qu'un fichier occupe sur disque.


3. Lectures dans un fichier binaire

Retourner le fichier entier dans une chaîne de caractères
KGF.dll: res% = dll_call2("ReadBinaryFileToString",adr(nom$),adr(buf$))
KGF_SUB.bas: ReadBinaryFileToString(nom$)

Cette fonction retourne une chaîne de caractères contenant la totalité du fichier binaire
sous forme de caractères binaires. Attention à la taille du fichier !

Retourner une chaîne de caractères contenant une partie d'un fichier binaire
KGF.dll: res% = dll_call4("ReadBlockFromBinaryFileToString",adr(nom$),n%,p%,adr(buf$))
KGF_SUB.bas: ReadBlockFromBinaryFileToString(nom$,n%,p%)

Cette fonction retourne une chaîne de caractères contenant la partie du fichier binaire
spécifiée par une position (1, 2, ...) et une longueur.

Retourner une variable de type entier ou flottant à partir d'un fichier binaire
KGF.dll: res% = dll_call5("ReadBlockFromBinaryFile",nom$,adr%,n%,p%)
KGF_SUB.bas: ReadBlockFromBinaryFile(nom$,adr%,n%,p%)

Cette fonction retourne une variable de type entier ou flottant, contenant la partie du fichier
binaire spécifiée par une position (1, 2, ...) et une longueur obligatoirement 4 (pour un
entier) ou 8 (pour un flottant).

Retourner une valeur entière à partir d'un fichier binaire
KGF.dll: res% = dll_call5("ReadBlockFromBinaryFile",nom$,adr(i%),4,p%)
KGF_SUB.bas: ReadBlockFromBinaryFileToInteger(nom$,p%)

Cette fonction retourne une variable de type entier contenant la partie du fichier
binaire spécifiée par une position (1, 2, ...) et une longueur de 4 octets. La valeur
entière est retournée dans la variable ReadBlockFromBinaryFileToInteger% dans
la cas de l'utilisation de KGF_SUB.bas.

Retourner une valeur flottante à partir d'un fichier binaire
KGF.dll: res% = dll_call5("ReadBlockFromBinaryFile",nom$,adr(v),8,p%)
KGF_SUB.bas: ReadBlockFromBinaryFileToFloat(nom$,p%)

Cette fonction retourne une variable de type flottant contenant la partie du fichier
binaire spécifiée par une position (1, 2, ...) et une longueur de 8 octets. La valeur
flottante est retournée dans la variable ReadBlockFromBinaryFileToFloat dans
la cas de l'utilisation de KGF_SUB.bas.


4. Ecritures dans un fichier binaire

Créer un fichier binaire à partir d'une chaîne de caractères
KGF.dll: res% = dll_call2("WriteStringToBinaryFile",adr(nom$),adr(buf$))
KGF_SUB.bas: WriteStringToBinaryFile(nom$,buf$)

Cette fonction crée un nouveau fichier, dont le contenu sera la chaîne de caractères.

Ajouter une chaîne de caractères à la fin d'un fichier binaire
KGF.dll: res% = dll_call2("AppendStringToBinaryFile",adr(nom$),adr(buf$))
KGF_SUB.bas: AppendStringToBinaryFile(nom$,buf$)

Cette fonction ajoute une chaîne de caractères à la fin d'un fichier binaire. Si le fichier
n'existe pas, il sera créé et contiendra cette chaîne.

Remplacer une chaîne de caractères dans un fichier binaire
KGF.dll: res% = dll_call6("ReplaceStringInBinaryFile",adr(nom$),adr(buf$),adr(fill$),n%,p%,flag%)
KGF_SUB.bas: ReplaceStringInBinaryFile(nom$,buf$,fill$,n%,p%,flag%)

Cette fonction remplace une section d'un fichier binaire, déterminée par la position (1, 2, ...)
et une longueur, par une chaîne de caractères. Si le flag est 0, la section sera remplacée par la
chaîne de caractères, et la taille du fichier peut changer. Si le flag est 1, la talle ne change pas,
et la chaîne remplaçante sera tronquée ou complétée par un caractère de remplissage selon besoin.

Ecrire une valeur entière ou flottante dans un fichier binaire
KGF.dll: res% = dll_call6("ReplaceBlockInBinaryFile",adr(nom$),adr(block),n%,p%)
KGF_SUB.bas: sub ReplaceBlockInBinaryFile(nom$,adr%,n%,p%,flag%)

Cette fonction écrit une valeur entière ou flottante dans un fichier binaire, à partir d'une position
(1, 2, ...), et obligatoirement sur une longueur de 4 (entier) ou 8 (flottant).

Ecrire une valeur entière dans un fichier binaire
KGF.dll: res% = dll_call6("ReplaceBlockInBinaryFile",adr(nom$),adr(i%),4,p%)
KGF_SUB.bas: ReplaceBlockInBinaryFileByInteger(nom$,i%,p%,flag%)

Cette fonction écrit une valeur entière dans un fichier binaire, à partir d'une position (1, 2, ...),
et obligatoirement sur une longueur de 4 octets.

Ecrire une valeur flottante dans un fichier binaire
KGF.dll: res% = dll_call6("ReplaceBlockInBinaryFile",adr(nom$),adr(v),8,p%)
KGF_SUB.bas: ReplaceBlockInBinaryFileByFloat(nom$,v,p%,flag%)

Cette fonction écrit une valeur flottante dans un fichier binaire, à partir d'une position (1, 2, ...),
et obligatoirement sur une longueur de 8 octets.

Et voici le programme de démo adapté à cette version:
Code:
' demo_fichiers_binaires_zones_fixes.bas

' Ce programme crée un fichier binaire contenant
' 12 "enregistrements" ayant chacun 3 zones:
'    1 entier contenant le numéro d'enregistrement
'    1 flottant contenant le numéro d'enregistrement * 3 + 0.17
'    1 chaîne de caractères contenant str$(zone flottante)
' Afin de produire des enregsitrements de longueur fixe,
' la 3ème zone est fixée à 60 caractères. Chaque enregsitrement
' a donc 4 + 8 + 60 = 72 caractères.
'
' Le programme propose une zone pour saisir un numéro d'enregistrement
' entre 1 et 12, un bouton "Lire" et un mémo montrant les données lues.

label lire, sortie

dim i%, v, s$, buf$, n%, p%, num%
dim nom$ : nom$ = "test_fichier_binaire.dat"

on_close 0,sortie

alpha 1 : top 1,20 : left 1,20 : caption 1,"Enregistrement (1...12):"
edit 11 : top 11,20 : left 11,150 : width 11,40 : text 11,"0"
button 12 : top 12,50 : left 12,150 : caption 12,"Lire" : on_click 12,lire
memo 13 : top 13,80 : left 13,150 : width 13,300 : height 13,300

KGF_initialize("KGF.dll")

OpenBinaryFile(nom$)

' on crée d'abord un fichier "vide" de 12*72 caractères,
' soit 864 caractères
buf$ = string$(12*72," ")
WriteStringToBinaryFile(nom$,buf$)

' boucle pour la création des 12 enregistrements
for i%=1 to 12
  ' la variable i% est la zone 1
  ' on construit la zone 2
  v = i%*3 + 0.17
  ' et la zone 3
  s$ = left$(str$(v)+string$(60," "),60)
  ' on écrit l'enregistrement à sa place
  p% = (i%-1)*72 + 1 : ' calculer la position de début
  ' d'abord, écrire la zone 1:
  ReplaceBlockInBinaryFileByInteger(nom$,i%,p%,0)
  ' puis, écrire la zone 2:
  ReplaceBlockInBinaryFileByFloat(nom$,v,p%+4,0)
  ' enfin, écrire la zone 3:
  ReplaceBlockInBinaryFile(nom$,adr(s$),60,p%+12,1)
next i%

end

lire:
  if numeric(text$(11))=0
    message "Invalide."
    return
  end_if
  num% = val(text$(11))
  if num%<1 or num%>12
    message "Invalide."
    return
  end_if
  p% = (num%-1)*72 + 1 : ' calculer la position de début
  clear 13
  item_add 13,"Enregistrement "+str$(num%)
  ' d'abord lire la zone 1
  i% = 0
  ReadBlockFromBinaryFileToInteger(nom$,p%)
  item_add 13,"Zone 1: "+str$(ReadBlockFromBinaryFileToInteger%)
  ' puis, lire la zone 2:
  ReadBlockFromBinaryFileToFloat(nom$,p%+4)
  item_add 13,"zone 2: "+str$(ReadBlockFromBinaryFileToFloat)
  ' enfin, lire la zone 3:
  ReadBlockFromBinaryFileToString(nom$,60,p%+12)
  item_add 13,"Zone 3: ["+ReadBlockFromBinaryFileToString$+"]"
  return

sortie:
  CloseBinaryFile(nom$)
  return


#INCLUDE "KGF_SUB.bas"
Revenir en haut Aller en bas
Voir le profil de l'utilisateur http://klauspanoramic.comxa.com/index.html
Klaus

avatar

Nombre de messages : 10062
Age : 68
Localisation : Ile de France
Date d'inscription : 29/12/2009

MessageSujet: Re: 1.98 du 28/2/2013: OpenBinaryFile et CloseBinaryFile   Ven 1 Mar 2013 - 2:22

Et la doc est à jour:
KGF.chm, KGF.doc et KGF.pdf dans MyDrive dossier DLLs\Documentation CHM !

Il y a une nouvelle catégorie de fonctions: Gestion de fichiers binaires.
Revenir en haut Aller en bas
Voir le profil de l'utilisateur http://klauspanoramic.comxa.com/index.html
 
1.98 du 28/2/2013: OpenBinaryFile et CloseBinaryFile
Voir le sujet précédent Voir le sujet suivant Revenir en haut 
Page 1 sur 1
 Sujets similaires
-
» [festival] - Le Troll et légende - le 29, 30, 31 mars 2013
» [Résolu] Comment Transférer d'un carte SD à Mapsource CN Europe 2013
» pas de carte 2013 après téléchargement
» Quelques captures de Comodo Internet Security 2013
» Mise à jour CN 2013.20 Impossible sur Zümo 660....!

Permission de ce forum:Vous ne pouvez pas répondre aux sujets dans ce forum
FORUM DE DISCUSSION SUR LE LANGAGE PANORAMIC :: Activité des sites créés par les Panoramiciens. :: Le site de Klaus-
Sauter vers: