Section courante

A propos

Section administrative du site

 Langage  Elément  Programmation  Compilateur  IDE  Annexe  Aide 
ABAP/4
Ada
Assembleur
Assembly & bytecode
ASP (Active Server Pages)
Basic
C
C++
C# (C Sharp)
Cobol
ColdFusion
Fortran
HTML
Java
JavaScript
LISP
Logo
LotusScript
Oberon
Pascal
Perl
PHP
PL/1
Prolog
Python
Rebol
REXX
Ruby
Rust
SAS
NoSQL
SQL
Swift
X++ (Axapta)
GNAT
SMALLAda
VHDL
Assembleur 370
Assembleur 1802
Assembleur 4004
Assembleur 6502
Assembleur 6800
Assembleur 68000
Assembleur 8080 et 8085
Assembleur 8089
Assembleur 80x86
Assembleur AGC4
Assembleur ARM
Assembleur DPS 8000
Assembleur i860
Assembleur Itanium
Assembleur MIPS
Assembleur PDP-11
Assembleur PowerPC
Assembleur RISC-V
Assembleur SPARC
Assembleur SuperH
Assembleur UNIVAC I
Assembleur VAX
Assembleur Z80
Assembleur Z8000
Assembleur z/Architecture
ASSEMBLER/MONITOR 64
Micol Assembler
GFA Assembler
A86
MASM (Macro Assembler)
TASM (Turbo Assembler)
CIL
Jasmin
LLVM
MSIL
Parrot
P-Code (PCode)
SWEET16
G-Pascal
ASP 1.0
ASP 2.0
ASP 3.0
ASP.NET
ASP.NET Core
ABasiC (Amiga)
Adam SmartBASIC
Altair BASIC
AmigaBASIC (Amiga)
AMOS Basic (Amiga)
Atari Basic (Atari 400, 600 XL, 800, 800XL)
Basic Apple II (Integer BASIC/APPLESOFT)
Basic Commodore 64 (CBM-BASIC)
Basic Commodore 128 (BASIC 7.0)
Basic Commodore VIC-20 (CBM-BASIC 2.0)
Basic Coco 1 (Color Basic)
Basic Coco 2 (Extended Color Basic)
Basic Coco 3 (Extended Color Basic 2.0)
BASICA (PC DOS)
Basic Pro
BBC BASIC
Blitz BASIC (Amiga)
DarkBASIC
Dartmouth BASIC
GFA-Basic (Atari ST/Amiga)
GWBASIC (MS-DOS)
Liberty BASIC
Locomotive BASIC (Amstrad CPC)
MSX-Basic
Omikron Basic (Atari ST)
Oric Extended Basic
Power Basic
Quick Basic/QBasic (MS-DOS)
Sinclair BASIC (ZX80, ZX81, ZX Spectrum)
ST BASIC (Atari ST)
Turbo Basic
Vintage BASIC
VBScript
Visual Basic (VB)
Visual Basic .NET (VB .NET)
Visual Basic pour DOS
Yabasic
BeckerBASIC
SIMONS' BASIC
Basic09 d'OS-9
Disk Extended Color Basic
Basic09 d'OS-9
Disk Extended Color Basic
Access
Excel
Visual Basic pour Windows
Visual Basic .NET pour Windows
C Shell Unix (csh)
C pour Amiga
C pour Atari ST
C pour DOS
C pour Falcon030
C pour GEMDOS (Atari ST)
C pour Linux
C pour PowerTV OS
C pour OS/2
C pour Unix
C pour Windows
Aztec C
CoCo-C
GNU C
HiSoft C
IBM C/2
Introl-C
Lattice C
Microsoft C
MinGW C
MSX-C
Open Watcom C
OS-9 C Compiler
Pure C
Quick C
Turbo C
HiSoft C for Atari ST
HiSoft C for CP/M (Amstrad CPC)
C++ pour OS/2
C++ pour Windows
Borland C++
C++Builder
IBM VisualAge C++
Intel C++
MinGW C++
Open Watcom C++
Symantec C++
Turbo C++
Visual C++
Visual C++ .NET
Watcom C++
Zortech C++
C# (C Sharp) pour Windows
Apple III Cobol
Microsoft Cobol
BlueDragon
Lucee
OpenBD
Railo
Smith Project
Microsoft Fortran
WATFOR-77
CSS
FBML
Open Graph
SVG
XML
XSL/XSLT
LESS
SASS
GCJ (GNU)
JSP
Jython
Visual J++
Node.js
TypeScript
AutoLISP
ACSLogo
LotusScript pour Windows
Amiga Oberon
Oberon .NET
Apple Pascal
Delphi/Kylix/Lazarus
Free Pascal
GNU Pascal
HighSpeed Pascal
IBM Personal Computer Pascal
Lisa Pascal
Maxon Pascal
MPW Pascal
OS-9 Pascal
OSS Personal Pascal
Pascal-86
Pascal du Cray Research
Pascal/VS
Pascal-XT
PURE Pascal
QuickPascal
RemObjets Chrome
Sun Pascal
THINK Pascal
Tiny Pascal (TRS-80)
Turbo Pascal
UCSD Pascal
VAX Pascal
Virtual Pascal
Turbo Pascal for CP/M-80
Turbo Pascal for DOS
Turbo Pascal for Macintosh
Turbo Pascal for Windows
CodeIgniter (Cadre d'application)
Drupal (Projet)
Joomla! (Projet)
Phalanger (PHP .NET)
phpBB (Projet)
Smarty (balise)
Twig (balise)
Symfony (Cadre d'application)
WordPress (Projet)
Zend (Cadre d'application)
PL360
PL/M-80
PL/M-86
Turbo Prolog
CPython
IronPython
Jython
PyPy
AREXX
Regina REXX
JMP
Btrieve
Cassandra
Clipper
CouchDB
dBASE
Hbase
Hypertable
MongoDB
Redis
Access
BigQuery
DB2
H2
Interbase
MySQL
Oracle
PostgreSQL
SAP HANA
SQL Server
Sybase
U-SQL
Type de données
EXE, DLL et modules pour OS/2
API pour OS/2
DOSCALLS.DLL
FKA.DLL
KBDCALLS.DLL
PMGPI.DLL
PMMERGE.DLL
PMSHAPI.DLL
PMWIN.DLL
QUECALLS.DLL
SESMGR.DLL
VIOCALLS.DLL
Géométrie
Treillis
IBM C/2
IBM VisualAge C++
Lattice C
Open Watcom C/C++
Borland C++ for OS/2 Version 1.0
Codes d'erreurs
Bibliographie
Préface
Notes légal
Dictionnaire
Recherche

WinCreateStdWindow

Fenêtre : Crée une fenêtre standard
PMWIN.DLL os2.h

Syntaxe

HWND WinCreateStdWindow( HWND hwndParent, ULONG flFrameStyle, PULONG pflCreateFlags, PSZ pszClientClass, PSZ pszTitle, ULONG flClientStyle, HMODULE hmodResource, ULONG ulFrameId, PHWND pwhndClient );

Paramètres

Nom Description
hwndParent Ce paramètre permet d'indiquer Handle de la fenêtre parente.
flFrameStyle Ce paramètre permet d'indiquer le style de fenêtre. Voici les styles les plus communs prédéfinit pour le gestionnaire de présentation :
Constante Description
FS_AUTOICON Cette constante permet d'indiquer que le système redessine l'icône pour l'application.
FS_BORDER Cette constante permet d'indiquer une fenêtre avec une fine bordure.
FS_DLGBORDER Cette constante permet d'indiquer une fenêtre avec une bordure de dialogue.
FS_MOUSEALIGN Cette constante permet d'indiquer la position relative de la position de la souris.
FS_NOBYTEALIGN Cette constante permet d'indiquer d'effectuer un déplacement non aligné d'octets proches. Lent, mais très beau.
FS_NOMOVEWITHOWNER Cette constante permet d'indiquer que la fenêtre ne doit pas être déplacer quand le propriétaire en fait la demande.
FS_SCREENALIGN Cette constante permet d'indiquer les coordonnées relatives en haut à gauche de l'écran.
FS_SIZEBORDER Cette constante permet d'indiquer que la fenêtre est avec des bordures de redimensionnement normal.
FS_SYSMODAL Cette constante permet d'indiquer une fenêtre de modèle système.
FS_TASKLIST Cette constante permet d'indiquer une fenêtre à ajouter dans la liste de tâche.
WS_ANIMATE Cette constante permet d'indiquer l'activation d'animation WPS, sauf si l'utilisateur a désactivé cette fonctionnalité.
WS_CLIPCHILDREN Cette constante permet d'indiquer une fenêtre n'étant pas dessiné dans un enfant.
WS_CLIPSIBLINGS Cette constante permet d'indiquer une fenêtre n'étant pas dessiné entre frère et soeur.
WS_DISABLED Cette constante permet d'indiquer que la création de fenêtre est désactivé.
WS_GROUP Cette constante permet d'indiquer qu'il faut débuter un nouveau de groupe de boite de dialogue.
WS_PARENTCLIP Cette constante permet d'indiquer que la fenêtre créé avec ce style n'est pas dessiné en dehors des limites de leur parent.
WS_SAVEBITS Cette constante permet d'indiquer que le gestionnaire de présentation doit sauvegarder les pixels de cette fenêtre pour que quand la fenêtre est fermé ou déplacé, elle se redessine plus vite.
WS_SYNCPAINTS Cette constante permet d'indiquer qu'un message WM_PAINT sera envoyé, plutôt que posté.
WS_TABSTOP Cette constante permet d'indiquer que lorsqu'on enfonce la touche de tabulation dans une boite de dialogue elle déplacera le focus dans cette fenêtre.
WS_VISIBLE Cette constante permet d'indiquer qu'un message WM_PAINT sera envoyé, plutôt que posté. Sans ce style, la fenêtre créé sera invisible, et devra être affichés plus tard avec WinSetWindowPos ou WinShowWindow.
pflCreateFlags Ce paramètre permet d'indiquer le nom de la classe. Doit déjà être enregistré via la fonction WinRegisterClass ou une classe prédéfinit du gestionnaire de présentation. Voici quelques unes des classes possibles :
Classe Description
FCF_ACCELTABLE Cette classe permet de spécifié les accélérateurs de raccourci clavier devant être chargé avec la ressource du fichier.
FCF_AUTOICON Cette classe permet d'automatiquement gérer les messages WM_PAINT tant que l'application en icône.
FCF_BORDER Cette classe permet de créer une fenêtre avec de fine bordure.
FCF_DLGBORDER Cette classe permet de créer une fenêtre avec des bordures fixe de style boite de dialogue.
FCF_HIDEBUTTON Cette classe permet d'ajouter un bouton caché dans un cadre.
FCF_HIDEMAX Cette classe permet d'ajouter un bouton caché et maximisé dans un cadre.
FCF_HORZSCROLL Cette classe permet d'ajouter une barre de défilement horizontal dans la fenêtre client.
FCF_ICON Cette classe permet d'utiliser une icône d'un fichier ressource d'une application d'icône.
FCF_MAXBUTTON Cette classe permet d'ajouter un bouton maximiser au cadre.
FCF_MENU Cette classe permet de charger un menu d'un fichier de ressource.
FCF_MINBUTTON Cette classe permet d'ajouter un bouton minimiser au cadre.
FCF_MINMAX Cette classe permet d'ajouter des boutons minimiser et maximiser au cadre.
FCF_MOUSEALIGN Cette classe permet de créer une fenêtre d'application relative à la position de la souris au moment de la création.
FCF_NOBYTEALIGN Cette classe permet de ne pas forcer l'alignement de la fenêtre dans un octet paire, contrairement aux fenêtres VIO.
FCF_NOMOVEWITHOWNER Cette classe permet de désactiver le mouvement de la fenêtre quand le propriétaire la déplace.
FCF_SCREENALIGN Cette classe permet de créer une fenêtre d'application relative au coin supérieur gauche de l'écran.
FCF_SHELLPOSITION Cette classe permet de redimensionnement automatiquement la taille d'une fenêtre d'application et de positionner la fenêtre avec le gestionnaire de présentation.
FCF_SIZEBORDER Cette classe permet de créer un cadre de fenêtre avec une bordure redimensionnable normalement.
FCF_STANDARD Cette classe permet de créer une fenêtre avec un système de fichier, un barre de titre, de minimiser et maximiser les boutons, le menu, la bordure redimensionnable, un icône, les raccourcis clavier, la position et la taille par défaut et une entrée dans la liste de tâche.
FCF_SYSMENU Cette classe permet de créer un cadre de fenêtre avec un menu système dans le coin supérieur gauche.
FCF_SYSMODAL Cette classe permet de créer une fenêtre de modèle système.
FCF_TASKLIST Cette classe permet de créer une entrée dans la liste de fenêtre pour les applications.
FCF_TITLEBAR Cette classe permet de créer un cadre de fenêtre avec une barre de titre.
FCF_VERTSCROLL Cette classe permet de créer une barre de défilement vertical dans une fenêtre client.
pszClientClass Ce paramètre permet d'indiquer une classe ayant un nom préenregistré.
pszTitle Ce paramètre permet d'indiquer un titre de fenêtre.
flClientStyle Ce paramètre permet d'indiquer des drapeaux indiquant le style de la fenêtre client.
hmodResource Ce paramètre permet d'indiquer le Handle du module ressource lequel est requis pour l'icône, le menu et la table d'accélérateur.
ulFrameId Ce paramètre permet d'indiquer la valeur donné par le programmeur afin d'identifier le propriétaire de la fenêtre.
pwhndClient Ce paramètre permet de retourner le HWND pour la nouvelle création de fenêtre.

Retour

Valeur Description
NULLHANDLE Cette valeurs permet d'indiquer qu'une erreur s'est produite, dans ce cas consulter la fonction WinGetLastError().
entier Ces valeurs permettent d'indiquer un identificateur de Handle de la nouvelle fenêtre.

Description

Cette fonction permet de créer une fenêtre de type de standard, dans une fenêtre principal d'une application.

Exemple

Voici un simple exemple montrant comme appeler cette API avec WatCom C++ for OS/2 :

  1. #define INCL_WINMESSAGEMGR
  2. #include "os2.h"
  3.  
  4. #define ID_APPLICATIONNAME 3
  5.  
  6. void main(void) {
  7.     HWND hwndMain, hwndClient;
  8.     PFNWP ClientWndProc;
  9.     ULONG pflCreateFlags = FCF_ACCELTABLE | FCF_ICON | FCF_MENU | FCF_MINMAX | FCF_SIZEBORDER | FCF_SYSMENU | FCF_TASKLIST | FCF_TITLEBAR;
  10.     CHAR szTitle;
  11.     HAB myhab = WinInitialize(0);
  12.     HMQ hmq = WinCreateMsgQueue(myhab, 0);
  13.     if(WinRegisterClass(myhab, "CLIENT",ClientWndProc, 0, 0)) {
  14.         WinLoadString(myhab, 0, ID_APPLICATIONNAME, sizeof(szTitle), szTitle);
  15.         hwndMain = WinCreateStdWindow(HWND_DESKTOP, WS_VISIBLE, &pflCreateFlags, "CLIENT", szTitle, 0, 0, ID_APPLICATIONNAME, &hwndClient);
  16.     }
  17. }

Voir également

Langage de programmation - C pour OS/2 - WinCreateWindow

Références

OS/2 Warp Presentation Manager API, Edition John Wiley, Joel Barnum, 1995, ISBN: 0-471-03873-3, page 17

PARTAGER CETTE PAGE SUR
Dernière mise à jour : Lundi, le 19 juillet 2010