mirror of
https://port.numenaute.org/aleajactaest/khanat-opennel-code.git
synced 2024-12-29 12:20:53 +00:00
2351 lines
90 KiB
Text
2351 lines
90 KiB
Text
|
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
// INTERFACE COMMANDS
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Fichier de definition des commandes et paramtres de l'interface
|
|||
|
|
|||
|
|
|||
|
Note: dans la syntaxe et la description des parmptres, la valeur indique est la valeur par dffaut
|
|||
|
|
|||
|
Note: le X va vers la droite, le Y vers le haut. Les valeurs sont en pixels
|
|||
|
|
|||
|
Note: DERIVANT DE veut dire qu'on peut mettre les meme parametres que celui de qui on derive
|
|||
|
les modifiables sont aussi herites
|
|||
|
|
|||
|
Note: MODIFIABLE veut dire que l'on peut modifier un paramtres dans le script (avec un link par exemple)
|
|||
|
|
|||
|
Note: OBLIGATOIRE veut dire que l'option doit tre presente sinon il y a crash ou non fonctionnement
|
|||
|
|
|||
|
Note: Identifiant de localisation local de type string (fait reference a un id de en.uxt par exemple)
|
|||
|
Identifiant de localisation reseau de type integer
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
// BASICS
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
chaque vue, control, ou group DERIVE DE interface_element et peut avoir les parametres suivant:
|
|||
|
|
|||
|
<view_ctrl_group
|
|||
|
id="" // id de l element. OBLIGATOIRE
|
|||
|
active="true" // affiche ou pas
|
|||
|
x="0" // position en X relative posref et posparent
|
|||
|
y="0" // position en Y relative posref et posparent
|
|||
|
w="0" // Taille de l element. Si l element possde un parent, prend le W du parent par defaut
|
|||
|
h="0" // Taille de l element. Si l element possde un parent, prend le H du parent par defaut
|
|||
|
posref="BL BL" // position de reference (Bottom Left, MiddleMiddle etc...)
|
|||
|
// Se lit "PositionDuParent MaPosition"
|
|||
|
// Ex: "BL TR" signifie "mon Top Right est fix<69> sur le Bottom Left du parent"
|
|||
|
posparent="parent" // Definit le parent de l element pour ce qui est du positionnement
|
|||
|
sizeref="" // valeurs possibles: "w", "h", "wh", "w?h?" ou ? est un facteur entre 1 et 9.
|
|||
|
// Dans ce cas la taille du parent est multiplie par ce facteur puis divisee par 10.
|
|||
|
// Au moment de l affichage, ajoute la taille du parent W ou/et H a celle definit par
|
|||
|
// w="" et h="". example: "w2h" implique que WAffiche = W + 2*parentW/10 et que
|
|||
|
// HAffiche = H + parentH
|
|||
|
sizeparent="" // Indique le parent que l on prend pour le calcul des tailles WAffiche et HAffiche si cette
|
|||
|
// valeur n est pas specifiee alors on prends le posparent pour le calcul de la taille
|
|||
|
global_color="true" // si true modulate la couleur par la couleur globale
|
|||
|
|
|||
|
render_layer="0" // valeur de -16 <20> +14 decale l ordre de rendu de l <20>lement.
|
|||
|
avoid_resize_parent="false" // Si cette valeur est mise a true, un group ayant un child_resize_x ne
|
|||
|
// prendra pas en compte cet element pour se resizer
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: active (bool)
|
|||
|
x, y, w, h (int)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
// VIEWS
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
Une vue a un type qui est dfinit par le parametre type="".
|
|||
|
|
|||
|
<view type="" />
|
|||
|
|
|||
|
MODIFIABLE: alpha (int)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <view type="bitmap" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
affiche une bitmap
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<view type="bitmap"
|
|||
|
color="255 255 255 255" // couleur (modulate) de la bitmap
|
|||
|
texture="" // fichier de la texture
|
|||
|
scale="false" // si false, le W et le H sont forcs 7 etre de la taille de la texture
|
|||
|
rot="0" // definit valeur de rotation de la bitmap
|
|||
|
flip="false"
|
|||
|
tile="false"
|
|||
|
align="0"
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: color (string)
|
|||
|
color_as_int (int)
|
|||
|
color_rgba (rgba)
|
|||
|
texture (string)
|
|||
|
alpha (int)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <view type="background" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
Vue DERIVANT DE <view type="bitmap" />
|
|||
|
|
|||
|
BUT:
|
|||
|
affiche une bitmap dans des textures non condenses (plusieurs textures dans une seule)
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<view type="background"
|
|||
|
txtoffsetx="0" // offset dans la texture (en haut a gauche et positif vers le bas a droite)
|
|||
|
txtoffsety="24" // offset dans la texture
|
|||
|
txtwidth="800" // taille de la texture
|
|||
|
txtheight="488"
|
|||
|
/>
|
|||
|
|
|||
|
texture sert pour le nom de la texture toute seule
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <view type="text" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
affiche un text
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<view type="text"
|
|||
|
color="255 255 255 255" // couleur (modulate) du text
|
|||
|
fontsize="12"
|
|||
|
shadow="false"
|
|||
|
shadow_color="0 0 0 255" // la couleur de l ombre du texte
|
|||
|
hardtext="" // si present definit le text afficher. (Identifiant de localisation local)
|
|||
|
multi_line="false"
|
|||
|
multi_line_space="8"
|
|||
|
justification="dont_clip_word" // clip_word : pas de justification
|
|||
|
// dont_clip_word : Mots non coup<75>s et non justifi<66>s
|
|||
|
// justified : Mots non coup<75>s et justifi<66>s
|
|||
|
underlined="false" // sous ligne la phrase
|
|||
|
case_mode="0" // Regle de majuscule
|
|||
|
// 0 : CaseNormal Pas de modification majuscule minuscule
|
|||
|
// 1 : CaseLower Toutes les lettres sont force en minuscule
|
|||
|
// 2 : CaseUpper Toutes les lettres sont forcees en majuscule
|
|||
|
// 3 : CaseFirstStringLetterUp La premiere lettre de la string est en majuscule
|
|||
|
// 4 : CaseFirstSentenceLetterUp La premiere lettre de la string et des phrases
|
|||
|
// suivantes (separes par un .) sont en majuscule
|
|||
|
// 5 : CaseFirstWordLetterUp La premiere lettre de chaque mot est en majuscule
|
|||
|
|
|||
|
line_maxw="16384" // maximum size of the line (multiline: minimized with the current wreal of the parent)
|
|||
|
multi_line_maxw_only="false" // multiline: don t minimize linemaxw with parent wreal. Use only linemaxw
|
|||
|
|
|||
|
over_extend_view_text="false" // usefull only if some line_maxw specified. if true and if the text is clipped cause
|
|||
|
// of line_maxw, and if the mouse over the view text, then a special tooltip will be
|
|||
|
// displayed over, to show all the text
|
|||
|
over_extend_parent_rect="false" // true to use in conjunction of over_extend_view_text: the over area is the parent, not the view
|
|||
|
auto_clamp="true" // when set to true, dots '...' will be added to the end of the line if the text is clipped by its parent (single line only)
|
|||
|
continuous_update="true" // multiline text justification is recomputed continuously as the window parent is resized (not when the left button is released only)
|
|||
|
// default is "false"
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: hardtext (string)
|
|||
|
uc_hardtext (ucstring)
|
|||
|
color (string ('#r #g #b #a'))
|
|||
|
color_rgba (rgba)
|
|||
|
alpha (int)
|
|||
|
|
|||
|
NOTE: IL NE FAUT PAS mettre de sizeref sur une vue texte.
|
|||
|
|
|||
|
NOTE: Les vue textes peuvent prendre la forme de "TextFormatTagged".
|
|||
|
MAIS SEULES les vues textes multilignes interpr<70>tent correctement les tags.
|
|||
|
Les Tags possibles sont:
|
|||
|
@{F3DF} Tag De couleur (en hexadecimal, d<>fintion avec 0 <20> F (0 <20> 15 maxi only donc) pour chaque composante RGBA)
|
|||
|
@{T10} Tag de Tabulation. Le chiffre indique l'espacement minimum (en nombre de caract<63>re '_')
|
|||
|
|
|||
|
NOTE: Il n'est pas posssible de pr<70>ciser un TextFormatTaged, autrement que par code C++, ou via la fonction LUA:
|
|||
|
setTextFormatTaged()
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <view type="text_id" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Vue DERIVANT DE <view type="text" />
|
|||
|
affiche un text en fonction d'un identifiant reseau (c'est une chaine de character equivalent a set_server_string (ah))
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<view type="text"
|
|||
|
textid="" // lien database vers un identifiant ("UI:TEMP:VAR1") ou identifiant lui meme ("654123")
|
|||
|
dynamic_string="true" // si true la phrase est composee (CStringManagerClient::getDynString),
|
|||
|
// sinon c est un identifiant server (CStringManagerClient::getString)
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: textid (int)
|
|||
|
textid_dblink (string)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <view type="text_number" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Vue DERIVANT DE <view type="text" />
|
|||
|
Affiche une entre de la database (un nombre entier) sous forme de text
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<view type="text_number"
|
|||
|
value="" // Lien vers la database pour lire la valeur OBLIGATOIRE.
|
|||
|
positive="true"
|
|||
|
suffix=""
|
|||
|
prefix=""
|
|||
|
/>
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <view type="text_formated" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Vue DERIVANT DE <view type="text" />
|
|||
|
Affiche un texte. Si le texte contient les caracteres speciaux suivant, il y a un traitement particulier
|
|||
|
$p -> remplace par le nom du joueur
|
|||
|
$P -> remplace par le nom du joueur en lettre capitale
|
|||
|
$b -> remplace par le nom du NPC auquel le joueur est en train de parler
|
|||
|
$s -> remplace par le nom du NPC auquel le joueur est en train de parler (sans le titre)
|
|||
|
ui... -> remplace par la traduction i18n (puis effectue les remplacements precedent)
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<view type="text_formated"
|
|||
|
format="$b" // chaine a remplacer (par defaut chaine vide)
|
|||
|
/>
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <view type="text_id_formated" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Vue DERIVANT DE <view type="text_id" />
|
|||
|
Un peu dans le meme esprit que la vue text_formated. Elle possede les memes traitements particuliers que
|
|||
|
text_formated auxquels il faut y rajouter :
|
|||
|
$t -> remplace par la valeur du text id
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<view type="text_id_formated"
|
|||
|
format="$t" // Par defaut
|
|||
|
textid="SERVER:BOTCHAT:DM_CHOICE2:TITLE"
|
|||
|
/>
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <view type="text_quantity" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Vue DERIVANT DE <view type="text" />
|
|||
|
Affiche un nombre de la database sous la forme "8/10" (avec donc une valeur max de la database).
|
|||
|
Si le nombre est 0, cela affiche la string emptytext.
|
|||
|
Par defaut emptytext="", et dans ce cas, "0/80" est affich (80 est la vraie valeur max en fait)
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<view type="text_quantity"
|
|||
|
value="" // Lien vers la database pour lire la valeur OBLIGATOIRE.
|
|||
|
valuemax="" // Lien vers la database pour lire la valeur Max. OBLIGATOIRE.
|
|||
|
emptytext="" // quand valeur==0, string afficher. "" veut dire affiche 0/valeurMax
|
|||
|
/>
|
|||
|
|
|||
|
NB : emptytext contient un identifiant de localization local
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <view type="digit" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Vue speciale qui affiche un nombre avec des digits speciaux (bitmaps).
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<view type="digit"
|
|||
|
value="SERVER:...." // lien sur la database. OBLIGATOIRE
|
|||
|
numdigit="2" // nombre de digit affichs (eg 00 si la valeur est nulle). Defaut:2. Min:1 et Max: 10
|
|||
|
wspace="-1" // espacement en pixel entre chaque digit. Defaut: -1
|
|||
|
color="255 255 255 255" // comme les boutons, blanc par defaut
|
|||
|
/>
|
|||
|
|
|||
|
La taille totale est automatiquement calcule en fonction du digit 0 et du nombre de digit.
|
|||
|
bien sur, x,y,posref etc... marche toujours
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <view type="bar" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Vue DERIVANT DE <view type="bitmap" />
|
|||
|
affiche une valeur sous forme de bar. Pour l instant 4 versions : (normal, mini, ultra_mini et mini_thick)
|
|||
|
les bitmaps utilisees sont hardcodees en c++
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<view type="bar"
|
|||
|
value="" // valeur courante (Valeur ou Lien DB)
|
|||
|
range="" // range (Valeur ou Lien DB)
|
|||
|
reference="" // Valeur soustraire de value et range (exemple: gestion de temps).(Valeur ou Lien DB)
|
|||
|
color_negative="" // couleur quand les valeurs sont negatives
|
|||
|
mini="true" // Affiche la version mini
|
|||
|
ultra_mini="true" // Affiche la version ultra mini
|
|||
|
mini_thick="true" // Affiche la version mini thick
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE:
|
|||
|
value (int)
|
|||
|
range (int)
|
|||
|
reference (int)
|
|||
|
value_dblink (string)
|
|||
|
range_dblink (string)
|
|||
|
reference_dblink (string)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <view type="bar3" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Vue DERIVANT DE <view type="bitmap" />
|
|||
|
un peu dans le meme esprit que "bar" mais affiche directement 3 barres
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<view type="bar3"
|
|||
|
value1=""
|
|||
|
value2=""
|
|||
|
value3=""
|
|||
|
range1=""
|
|||
|
range2=""
|
|||
|
range3=""
|
|||
|
color1=""
|
|||
|
color2=""
|
|||
|
color3=""
|
|||
|
color1_negative=""
|
|||
|
color2_negative=""
|
|||
|
color3_negative=""
|
|||
|
mini="true"
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE:
|
|||
|
value1 (int)
|
|||
|
value2 (int)
|
|||
|
value3 (int)
|
|||
|
range1 (int)
|
|||
|
range2 (int)
|
|||
|
range3 (int)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
// CONTROLS
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
DERIVE DE <view type="" />
|
|||
|
Un control a un type qui est d<>finit par le param<61>tre type="".
|
|||
|
|
|||
|
<ctrl type=""
|
|||
|
tooltip="" // aide contextuelle par defuat
|
|||
|
tooltip_i18n="" // idem tooltip, mais cherche forc<72>ment la d<>finition dans le wk.uxt,
|
|||
|
// m<>me si le texte ne commence pas par "ui"
|
|||
|
on_tooltip="" // action handler qui permet de mettre une autre aide contextuelle
|
|||
|
on_tooltip_params="" // les parametres de l action handler
|
|||
|
instant_help="true" // Est ce que l aide contextuelle a affichee est affichee directement
|
|||
|
|
|||
|
tooltip_parent="ctrl" // "ctrl", "win" ou "mouse". D<>finit le parent relatif lors de l affichage
|
|||
|
// du tooltip.
|
|||
|
"ctrl" veut dire que le tooltip est call<6C> par rapport <20> ce control
|
|||
|
"win" veut dire que le tooltip est affich<63> par rapport <20> la fenetre
|
|||
|
contenant le control
|
|||
|
"mouse" veut dire que le tooltip est call<6C> par rapport <20> la souris
|
|||
|
tooltip_posref="auto" // Position de r<>f<EFBFBD>rence du tooltip par rapport <20> son parent (cf tooltip_parent)
|
|||
|
"auto" la posution de r<>f<EFBFBD>rence est chosie intelligement suivant le
|
|||
|
type de parent:
|
|||
|
"ctrl": "TL BR" ou "TR BL" suivant que la fenetre contenant
|
|||
|
le control est plus <20> gauche ou <20> droite
|
|||
|
"win": "TL BL" ou "BL TL" suivant que la fenetre contenant
|
|||
|
le control est plus en haut ou en bas
|
|||
|
"mouse": "BL BL"
|
|||
|
"TL BR" (ou toute autre position de r<>f<EFBFBD>rence possible): calage fixe
|
|||
|
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: alpha (int)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <ctrl type="tooltip" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Control qui d<>rive simplement de ctrl_base, et qui ne g<>re aucun <20>venement et n'affiche rien.
|
|||
|
Son seul but est d'avoir une zone pour afficher un tooltip quand on passe dessus.
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<ctrl type="tooltip" />
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <ctrl type="button" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
boutton, push, radio ou toggle.
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<ctrl type="button"
|
|||
|
button_type="toggle_button" // type du boutton: "toggle_button", "push_button" ou "radio_button"
|
|||
|
pushed="false" // etat pushed par defaut
|
|||
|
color="255 255 255 255" // couleur etat normal
|
|||
|
col_pushed="255 255 255 255" // couleur quand pushed
|
|||
|
col_over="255 255 255 255" // couelur quand over
|
|||
|
global_color_normal="" // remplace le setup global_color pour l etat normal du bouton
|
|||
|
global_color_pushed="" // remplace le setup global_color pour l etat pushed du bouton
|
|||
|
global_color_over="" // remplace le setup global_color pour l etat over du bouton
|
|||
|
tx_normal="" // texture etat normal
|
|||
|
tx_pushed="" // texture etat pushed
|
|||
|
tx_over="" // texture etat over
|
|||
|
scale="false"
|
|||
|
onclick_l="" // action <20> lancer sur un click gauche
|
|||
|
params_l="" // parametres de l action <20> lancer sur un click gauche
|
|||
|
onlongclick_l="" // action a lancer sur un click long
|
|||
|
params_longclick_l=""
|
|||
|
onclick_r="" // action <20> lancer sur un click droit
|
|||
|
params_r="" // parametres de l action <20> lancer sur un click droit
|
|||
|
align="" // si pas de scale et que zone d<>finie plus grande que l image
|
|||
|
menu_l="" // context menu <20> afficher sur un click bouton gauche (voir group de type menu)
|
|||
|
menu_r="" // context menu <20> afficher sur un click bouton droit (voir group de type menu)
|
|||
|
menu_b="" // context menu <20> afficher sur un click bouton droit ou gauche (voir group de type menu)
|
|||
|
frozen="false" // button is frozen
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: pushed (bool)
|
|||
|
col_normal (string ('#r #g #b #a'))
|
|||
|
col_over (string ('#r #g #b #a'))
|
|||
|
col_pushed (string ('#r #g #b #a'))
|
|||
|
col_normal_rgba (rgba)
|
|||
|
col_over_rgba (rgba)
|
|||
|
col_pushed_rgba (rgba)
|
|||
|
frozen (bool)
|
|||
|
params_l (string)
|
|||
|
|
|||
|
texture (string)
|
|||
|
texture_pushed (string)
|
|||
|
texture_over (string)
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <ctrl type="text_button" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
boutton, push, radio ou toggle.
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<ctrl type="text_button"
|
|||
|
button_type="toggle_button" // type du boutton: "toggle_button", "push_button" ou "radio_button"
|
|||
|
pushed="false" // etat pushed par defaut
|
|||
|
color="255 255 255 255" // couleur etat normal
|
|||
|
col_pushed="255 255 255 255" // couleur quand pushed
|
|||
|
col_over="255 255 255 255" // couelur quand over
|
|||
|
global_color_normal="" // remplace le setup global_color pour l etat normal du bouton
|
|||
|
global_color_pushed="" // remplace le setup global_color pour l etat pushed du bouton
|
|||
|
global_color_over="" // remplace le setup global_color pour l etat over du bouton
|
|||
|
|
|||
|
// Textures:
|
|||
|
// contrairement aux boutons, ici il faut mettre seulement "textb_normal" par exemple.
|
|||
|
// les "_l.tga", "_m.tga", "_r.tga" etant ajoutees automatiquement pour trouver respectivement les parties
|
|||
|
// gauches, millieu (celle qui est scal<61>e en X) et droite.
|
|||
|
|
|||
|
tx_normal="" // texture etat normal.
|
|||
|
tx_pushed="" // texture etat pushed.
|
|||
|
tx_over="" // texture etat over.
|
|||
|
onclick_l="" // action <20> lancer sur un click gauche
|
|||
|
params_l="" // parametres de l action <20> lancer sur un click gauche
|
|||
|
onlongclick_l="" // action a lancer sur un click long
|
|||
|
params_longclick_l=""
|
|||
|
onclick_r="" // action <20> lancer sur un click droit
|
|||
|
params_r="" // parametres de l action <20> lancer sur un click droit
|
|||
|
menu_l="" // context menu <20> afficher sur un click bouton gauche (voir group de type menu)
|
|||
|
menu_r="" // context menu <20> afficher sur un click bouton droit (voir group de type menu)
|
|||
|
menu_b="" // context menu <20> afficher sur un click bouton droit ou gauche (voir group de type menu)
|
|||
|
|
|||
|
// Texte infos:
|
|||
|
hardtext=""
|
|||
|
fontsize=""
|
|||
|
shadow=""
|
|||
|
underlined=""
|
|||
|
|
|||
|
// Comportement Special des Couleurs des Textes
|
|||
|
text_color_normal="255 255 255 255"
|
|||
|
text_color_pushed="255 255 255 255"
|
|||
|
text_color_over="255 255 255 255"
|
|||
|
text_shadow_color_normal="0 0 0 255"
|
|||
|
text_shadow_color_pushed="0 0 0 255"
|
|||
|
text_shadow_color_over="0 0 0 255"
|
|||
|
text_global_color_normal=""
|
|||
|
text_global_color_pushed=""
|
|||
|
text_global_color_over=""
|
|||
|
|
|||
|
// Special:
|
|||
|
text_y="" // d<>calage du texte en Y rapport au bouton (-2)
|
|||
|
wmargin="" // taille <20> ajouter au texte pour avoir la taille du bouton
|
|||
|
wmin="" // taille minimum du bouton
|
|||
|
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: pushed (bool)
|
|||
|
col_normal (string ('#r #g #b #a'))
|
|||
|
col_over (string ('#r #g #b #a'))
|
|||
|
col_pushed (string ('#r #g #b #a'))
|
|||
|
col_normal_rgba (rgba)
|
|||
|
col_over_rgba (rgba)
|
|||
|
col_pushed_rgba (rgba)
|
|||
|
frozen (bool)
|
|||
|
params_l (string)
|
|||
|
|
|||
|
uc_hardtext (ucstring telle quelle)
|
|||
|
hardtext (string qui va etre localisee)
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <ctrl type="scroll" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
scroll bar.
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<ctrl type="scroll"
|
|||
|
|
|||
|
tx_bottomleft="" // Les textures du bouton (pas de background affiche) (bottom or left)
|
|||
|
tx_middle=""
|
|||
|
tx_topright="" // top or right (ca depends si la sb est verticale)
|
|||
|
|
|||
|
vertical="" // Est ce que c est une sb verticale ou horizontale
|
|||
|
align="" // T, B, L ou R
|
|||
|
|
|||
|
value="" // Value entree de DB ou nombre (si pas present alors la sb est linke a une target)
|
|||
|
min="" // Si la sb n est pas linke a une target alors le nombre qu elle
|
|||
|
// represente varie de min a max
|
|||
|
tracksize="" // Taille de la track bar (le boutton)
|
|||
|
|
|||
|
onscroll="" // Action Handler appele lorsque la sb est deplacee
|
|||
|
onscrollend="" // Appele quand on arrete de scroller
|
|||
|
params=""
|
|||
|
|
|||
|
target="" // Si la sb n est pas linke a une value alors elle peut etre linke a un group. Dans ce cas
|
|||
|
// le group est se deplace dans la limite de ses max_w et max_h relativement a ses w et h.
|
|||
|
target_stepx="" // Donne la quantite de pixel a deplacer en une fois. Ce qui permet par exemple dans les
|
|||
|
target_stepy="" // listes de sheet d etre cale sur un sheet
|
|||
|
step_value=""
|
|||
|
/>
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <ctrl type="sheet" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
affiche un boutton sp<73>cial d'item, brique etc...
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<ctrl type="sheet"
|
|||
|
value="" // Lien vers la database. OBLIGATOIRE.
|
|||
|
// example: SERVER:INVENTORY:8:1. NB: lien vers une branche de la database
|
|||
|
// qui DOIT contenir SHEET, et peut avoir QUANTITY et/ou QUALITY
|
|||
|
nature="item" // "item", "brick", "spell"
|
|||
|
brick_type="" // "COMBAT", "MAGIC". may be important for some filter (memory...)
|
|||
|
// Can also put multiple filter like this: "COMBAT|MAGIC|HARVEST"
|
|||
|
tx_noitem=""
|
|||
|
col_noitem="true" // "true": quand pas d item, modulate la couleur avec la couelur globale
|
|||
|
|
|||
|
onclick_l="" // action <20> lancer sur un click gauche
|
|||
|
params_l="" // parametres de l action <20> lancer sur un click gauche
|
|||
|
onclick_r="" // action <20> lancer sur un click droit
|
|||
|
params_r="" // parametres de l action <20> lancer sur un click droit
|
|||
|
|
|||
|
menu_l="" // context menu <20> afficher sur un click bouton gauche (voir group de type menu)
|
|||
|
menu_r="" // context menu <20> afficher sur un click bouton droit (voir group de type menu)
|
|||
|
menu_b="" // context menu <20> afficher sur un click bouton droit ou gauche (voir group de type menu)
|
|||
|
|
|||
|
dragable="false" // drag and drop able?
|
|||
|
oncandrop="" // Action a lancer pour savoir si on peut Droper sur moi.
|
|||
|
params_candrop=""
|
|||
|
ondrop="" // Action a lancer sur un drop sur moi
|
|||
|
params_drop=""
|
|||
|
|
|||
|
use_quantity="true" // display the Item Quantity
|
|||
|
use_quality="true" // display the Item Quality
|
|||
|
duplicate_on_drag="false" // when drag a sheet (item only), leave the bitmap in the original slot
|
|||
|
use_slot_type_db_entry="false" // Automatic Type.
|
|||
|
|
|||
|
grayed="false" // init the sheet as grayed or not
|
|||
|
auto_grayed="false" // Gray auto the sheet according to Item LOCKED state or Brick LATENT state
|
|||
|
slot="true" // Draw the slot
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE:
|
|||
|
sheet (string) (correspond a la value le lien vers la DB)
|
|||
|
color1 (rgba)
|
|||
|
color2 (rgba)
|
|||
|
back (int)
|
|||
|
symbol (int)
|
|||
|
invert_symbol (bool)
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <ctrl type="colpick" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
affiche une image pour choisir que l on puisse choisir une couleur dedans
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<ctrl type="colpick"
|
|||
|
texture="color_palette.tga" // La texture a utiliser (texture non groupee!)
|
|||
|
onchange="proc" // Action a lancer des que la couleur selectionnee change
|
|||
|
onchange_params="proc_col_change" // Les parametres de l action
|
|||
|
dbcolr="UI:TEMP:COL:R" // .
|
|||
|
dbcolg="UI:TEMP:COL:G" // .
|
|||
|
dbcolb="UI:TEMP:COL:B" // .
|
|||
|
dbcola="UI:TEMP:COL:A" // Liens direct avec la database de la couleur selectionnee
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: r, g, b, a (int) les composantes de la couleur selectionnee
|
|||
|
color (string ('#r #g #b #a'))
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
// GROUPS
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group>
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
DERIVE DE <ctrl type=""/>
|
|||
|
D<EFBFBD>finit un group qui pourra contenir des groups, des controls ou des vues.
|
|||
|
Aucun affichage n'est fait sinon celui des fils
|
|||
|
Pour qu'un groupe soit affich<63>, il faut qu'il apparaisse dans les <tree node="">
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group
|
|||
|
overlappable="true" // Recupere les evenements
|
|||
|
child_resize_w="false" // si true, resize le groupe en W selon ses fils.
|
|||
|
child_resize_h="false" // si true, resize le groupe en H selon ses fils.
|
|||
|
child_resize_wmargin="0" // si child_resize_w="true" ajoute une marge <20> la largeur totale des fils
|
|||
|
child_resize_hmargin="0" // si child_resize_h="true" ajoute une marge <20> la hauteur totale des fils
|
|||
|
on_active="" // nom d un handler appel<65> quand la fenetre est activ<69>e
|
|||
|
on_active_params="" // parametre pass<73> au handler quand la fenetre est activ<69>e
|
|||
|
on_deactive="" // nom d un handler appel<65> quand la fenetre est d<>sactiv<69>e
|
|||
|
on_deactive_params="" // parametre pass<73> au handler quand la fenetre est sactiv<69>e
|
|||
|
on_enter="" // windows et modal only: Gere l evenement entree : Quand on appuie sur enter (return)
|
|||
|
on_enter_params="" // windows et modal only: Les parametres de l evenement entree
|
|||
|
escapable="false" // windows only: true : ferme la fenetre si ESC appuy<75>e.
|
|||
|
|
|||
|
max_w="" // max_w et max_h definisse la taille maximum a afficher tandis que w et h definsse la
|
|||
|
max_h="" // taille du document (qui est a l interieur et peut donc etre scolle)
|
|||
|
max_sizeref=""
|
|||
|
max_sizeparent=""
|
|||
|
group_onclick_r=""
|
|||
|
group_params_r=""
|
|||
|
group_onclick_l=""
|
|||
|
group_params_l=""
|
|||
|
win_priority=""
|
|||
|
use_cursor=""
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: ofsx (int)
|
|||
|
ofsy (int)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="list">
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="list"
|
|||
|
maxelements="10"
|
|||
|
addelt="B" // "B", "T", "L" ou "R"
|
|||
|
align="L" // "B", "T", "L" ou "R"
|
|||
|
space="0"
|
|||
|
chat="false"
|
|||
|
|
|||
|
// Text options
|
|||
|
color=""
|
|||
|
fontsize=""
|
|||
|
shadow=""
|
|||
|
shadow_color=""
|
|||
|
line_at_bottom=""
|
|||
|
multi_line=""
|
|||
|
justification=""
|
|||
|
multi_line_space=""
|
|||
|
|
|||
|
over="false" // doit on afficher la selection sous la souris
|
|||
|
col_over="255 255 255 32" // la couleur de la selection
|
|||
|
|
|||
|
// Initial text
|
|||
|
hardtext="uiAZE" // init la liste avec un texte a identifiant de localisation local
|
|||
|
textid="654" // init la liste avec un texte a identifiant de localisation reseau
|
|||
|
/>
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="container">
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
Herite de group
|
|||
|
|
|||
|
BUT:
|
|||
|
Afficher un container
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="container"
|
|||
|
localize="" // Def:true est ce que le titre doit etre localise ?
|
|||
|
title=""
|
|||
|
title_opened=""
|
|||
|
title_closed=""
|
|||
|
header_active="true"
|
|||
|
header_color="UI:SAVE:MYCOLOR" // db col entry
|
|||
|
right_button="true"
|
|||
|
movable="false" // true == on peut bouger la fenetre
|
|||
|
popable="false" // true == la fenetre peut se detacher de son container parent
|
|||
|
lockable="" // Def:true
|
|||
|
locked="" // Def:false
|
|||
|
openable="true" // peut on ouvrir le container en clickant sur la barre de titre
|
|||
|
opened="false" // l etat initial en ouverture
|
|||
|
open_when_popup="false" // Ouvre le container quand on le popup (le ferme quand popin)
|
|||
|
resizer="true" // est ce que l on peut resizer la fenetre
|
|||
|
|
|||
|
on_open="" // nom dun handler appel<65> quand le container est ouvert
|
|||
|
on_open_params="" // parametre pass<73> au handler quand le container est ouvert
|
|||
|
on_close="" // nom dun handler appel<65> quand le container est ferm<72>
|
|||
|
on_close_params="" // parametre pass<73> au handler quand le container est ferm<72>
|
|||
|
|
|||
|
on_deactive_check=""
|
|||
|
on_deactive_check_params=""
|
|||
|
|
|||
|
max_w=""
|
|||
|
min_w=""
|
|||
|
|
|||
|
pop_max_w=""
|
|||
|
pop_min_w=""
|
|||
|
pop_max_h=""
|
|||
|
pop_min_h=""
|
|||
|
|
|||
|
movable_in_parent_list=""
|
|||
|
savable="true" // true == la fenetre est sauvegard<72>e sur disque et est d<>pendente des modes.
|
|||
|
active_savable=""
|
|||
|
modal_parent=""
|
|||
|
options="" // nom des options a utilisees (pas fonction d un layer)
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: title, title_opened, title_closed (string)
|
|||
|
uc_title_opened, uc_title_closed, uc_title (ucstring)
|
|||
|
title_color (string)
|
|||
|
pop_max_h (int)
|
|||
|
openable, opened (bool)
|
|||
|
lockable, locked (bool)
|
|||
|
|
|||
|
Note: si global_color est <20> true le bouton et le titre sont color<6F>s par la couleur globale
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="frame">
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
Herite de group
|
|||
|
|
|||
|
BUT:
|
|||
|
comme un group mais affiche un cadre et un fond (fix<69>: bitmaps de la modal).
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="frame"
|
|||
|
display="false" // si false n affiche pas la frame (true par defaut)
|
|||
|
color="255 255 255 255"
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: color (string ('#r #g #b #a'))
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="modal">
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
Herite du group de type "frame" (affiche donc un cadre)
|
|||
|
|
|||
|
BUT:
|
|||
|
Affiche une fenetre qui pourra etre ouverte sur une action. Cach<63>e par defaut (active=false)
|
|||
|
NOTE: un group modal NE DOIT PAS <20>tre d<>fini dans les <tree node="">.
|
|||
|
En fait ils sont automatiquement ajout<75>s
|
|||
|
NB: par defaut les modals sont ESCAPABLE
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="modal"
|
|||
|
mouse_pos="true" // si "true", Spawn la fenetre sur la position de la souris, en suivant posref""
|
|||
|
// par exemple posref="BL TL" positionnera le coin TL de la fenetre sur la souris.
|
|||
|
// NB: BL (posref du parent) est donc ignor<6F>e ici
|
|||
|
exit_click_out="true" // si "true" la fenetre modal est ferme<6D> si on clique <20> l exteriru
|
|||
|
exit_click_l="false" // si "true" la fenetre modal est ferme<6D> si on clique sur le bouton gauche
|
|||
|
// (apr<70>s lancement eventuelle action de la modal)
|
|||
|
exit_click_r="false" // si "true" la fenetre modal est ferme<6D> si on clique sur le bouton droit
|
|||
|
// (apr<70>s lancement eventuelle action de la modal)
|
|||
|
exit_click_b="false" // equivalent <20> exit_click_l="val" ET exit_click_r="val" (val: true ou false)
|
|||
|
exit_key_pushed="false" // Close the modal if a key is pushed
|
|||
|
|
|||
|
force_inside_screen="false" // Clip la fenetre <20> l interieur de l ecran. Note: automatique si mouse_pos="true"
|
|||
|
onclick_out=""
|
|||
|
onclick_out_params=""
|
|||
|
/>
|
|||
|
|
|||
|
certains actions handlers prennent un id de window en param<61>tre (eg: "ui:interface:taskbar"). L'id sp<73>cial
|
|||
|
se nommant "ctrl_launch_modal" d<>signe en fait le bouton ou le control qui a fait ouvrir la fenetre modal.
|
|||
|
|
|||
|
eg:
|
|||
|
Un control sheet dans une fenetre modal echange son sheet id avec le ctrl sheet qui a ouvert la modal:
|
|||
|
<ctrl type="sheet" onclick_l="exchange" params_l="src=ctrl_launch_modal">
|
|||
|
|
|||
|
Dans le xml, il faut bien faire attention a ce que les modals soient a la racine sinon elles peuvent
|
|||
|
etre affich<63>es plusieurs fois. Il ne faut pas non plus qu'elles soient ajout<75>es en tant que node dans un <tree>
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="menu">
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
Herite du groupe de type "modal"
|
|||
|
|
|||
|
BUT:
|
|||
|
Affiche un menu contextuel
|
|||
|
Cach<EFBFBD> par d<>faut
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="menu" id="cm_byes"
|
|||
|
context="true" // "false" si doit etre utilis<69> (et donc affich<63>) dans un autre groupe
|
|||
|
// et non tout seul (sur un menu_r de bouton par exemple)
|
|||
|
color="255 255 255 255" // couleur du texte
|
|||
|
shadow_color="0 0 0 255" // couleur de l ombre du texte (noire par defaut)
|
|||
|
fontsize="12"
|
|||
|
shadow="false"
|
|||
|
color_over="255 255 255 255" // couleur du texte quand survole de la souris dessus
|
|||
|
shadow_color_over="0 0 0 255" // couleur de l ombre du texte quand survole de la souris (noire par defaut)
|
|||
|
highlight_over="128 0 0 255" // higlight sous le texte quand survol<6F>. Mettre A=0 pour rien.
|
|||
|
color_grayed="128 128 128 255" // couleur du texte quand celui ci est inactif
|
|||
|
shadow_color_grayed="0 0 0 255" // couleur de l ombre du texte quand celui ci est inactif
|
|||
|
>
|
|||
|
<action // Une action est une ligne de menu (ou de sous menu) (ici cette action poss<73>de un sous menu)
|
|||
|
id="aze" // Identifiant facultatif si absent, l id est la position dans le menu (a partir de 0)
|
|||
|
name="Action1" // Nom localise et affiche
|
|||
|
handler="" // handler appele si la ligne est clickee (meme en cas de sous menu)
|
|||
|
params="" // Les param<61>tres du handler
|
|||
|
grayed="true" // est ce que la ligne est gris<69>e ? facultatif
|
|||
|
usergroup_l="" // Nom d un template pour mettre un groupe a gauche du texte
|
|||
|
usergroup_params_l="" // Parametres du template delimites par des | (...params_l="posref=TL TL|x=5" )
|
|||
|
usergroup_r="" // Pareil a droite
|
|||
|
usergroup_params_r=""
|
|||
|
>
|
|||
|
<action name="imbriquee" handler="" params="" /> // Ligne simple
|
|||
|
</action>
|
|||
|
|
|||
|
|
|||
|
...
|
|||
|
</group>
|
|||
|
|
|||
|
MODIFIABLE: pour une action : grayed, checked et tous les modifiables d une vue texte
|
|||
|
on peut recuperer les usergroup en faisant comme d'habitude menuid:actionid:usergroupid
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="list_sheet">
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
affiche une liste variable de ctrl_sheet
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="list_sheet" id="pipo0"
|
|||
|
|
|||
|
value="SERVER:INVENTORY:8" // Pointe sur une branche de la database. OBLIGATOIRE
|
|||
|
// Les fils doivent etre de type #number:SHEET (optionnel #number:QUALITY et #number:QUANTITY).
|
|||
|
|
|||
|
wspace="2" hspace="2" // donne l espacement entre chaque slot. 0 par defaut
|
|||
|
|
|||
|
maxitem="12" // donne le nombre maximum d item lu dans la branch (eg: 6 pour un bag).
|
|||
|
// Nb: temporaire??, normalement c la database qui donne ce nombre. Defaut: infini
|
|||
|
|
|||
|
startitem="12" // donne l id de d<>part dans la database. utile pour les bag (bag0: 0, bag1: 6, bag2: 12, etc...)
|
|||
|
|
|||
|
array="false" // si "false", les sheet vides ne sont pas affich<63>s. defaut: "true"
|
|||
|
|
|||
|
lmargin="12" // Marges left, right Top et bottom des slots par rapport au group. Defaut:0. Il Faut en mettre si ya une scrollBar et des bouton +- forc<72>ment...
|
|||
|
rmargin="2"
|
|||
|
tmargin="12"
|
|||
|
bmargin="2"
|
|||
|
|
|||
|
rowmin="0" // Nombre de ligne minium affich<63>es. Defaut: 1.
|
|||
|
// Important si on veut par exemple afficher la liste des malus vide sans que le groupe se resize <20> H=0 (vide)
|
|||
|
|
|||
|
rowmax="2" // Nombre de ligne maximum affich<63>s. Defaut: infini.
|
|||
|
// Important si on veut afficher qu une seule ligne toujours (pour les malus par exemple)
|
|||
|
// quelque soit la largeur du parent. C est cette valeur qui est <20>dit<69>e par les boutons +- (si pr<70>sents)
|
|||
|
|
|||
|
column_max="4294967295" // taille maximum du nombre de sheet par ligne
|
|||
|
column_factor="1" // si 3 par exemple, le nombre de sheet par ligne ne pourra etre que 3,6,9...
|
|||
|
column_center="false" // si true, centre les sheet en X suivant le WReal donn<6E>e par list_sheet
|
|||
|
|
|||
|
// Param<61>tres communs au ctrl type="sheet". Voir ce control pour les d<>tails
|
|||
|
|
|||
|
nature=""
|
|||
|
tx_noitem=""
|
|||
|
onclick_l=""
|
|||
|
params_l=""
|
|||
|
onclick_r=""
|
|||
|
params_r=""
|
|||
|
dragable=""
|
|||
|
oncandrop=""
|
|||
|
params_candrop=""
|
|||
|
ondrop=""
|
|||
|
params_drop=""
|
|||
|
menu_l=""
|
|||
|
menu_r=""
|
|||
|
menu_b=""
|
|||
|
|
|||
|
// Filters
|
|||
|
|
|||
|
onfilter=""
|
|||
|
params_filter=""
|
|||
|
>
|
|||
|
|
|||
|
// Le mode "Resize" n'existe pas en fait. Le scripteur est libre de mettre ou pas une scroll bar et/ou des boutons qui permettent de changer rowmax
|
|||
|
|
|||
|
<ctrl type="button" id="add_row" button_type="push_button" posref="TR TR" tx_normal="W_arrow_up_3.tga" tx_pushed="W_arrow_up_3.tga" tx_over="W_button_08_over.tga" />
|
|||
|
<ctrl type="button" id="sub_row" button_type="push_button" posparent="add_row" posref="TL TR" tx_normal="W_arrow_down_3.tga" tx_pushed="W_arrow_down_3.tga" tx_over="W_button_08_over.tga" />
|
|||
|
|
|||
|
// Setup tyipque de scrollBar. L'alignement est hardoc<6F> pour etre Top. Le y devrait etre egal <20> "-tmargin" du group list_sheet
|
|||
|
|
|||
|
<ctrl type="scroll" id="scroll_row" posref="TL TL" w="8" x="2" y="12"
|
|||
|
<!-- choix des textures de la scroll -->
|
|||
|
tx_bottomleft= "w_scroll_l123_b.tga"
|
|||
|
tx_middle= "w_scroll_l123_m.tga"
|
|||
|
tx_topright= "w_scroll_l123_t.tga"
|
|||
|
/>
|
|||
|
|
|||
|
</group>
|
|||
|
|
|||
|
MODIFIABLE: nbelt (int en lecture seul !) le nombre d'element valide si array=false sinon maxelt
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="list_job">
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
affiche un tableau de familles de m<>tier avec la bonne brick.
|
|||
|
sont grand pere DOIT etre un container (pour initialiser son nom)
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="list_job"
|
|||
|
|
|||
|
brick_type="" // MAGIC, COMBAT, FABER,... Obligatoire!!
|
|||
|
career="" // index OBLIGATOIRE de la carriere
|
|||
|
job="" // index OBLIGATOIRE du job. -1 si "all"
|
|||
|
level="" // varaible database qui donne le level du joueur dans ce job. OBLIGATOIRE
|
|||
|
wspace="0" // donne l espacement entre chaque slot. 0 par defaut
|
|||
|
hspace="0" // donne l espacement entre chaque slot. 0 par defaut
|
|||
|
lmargin="0" // Marges left, right Top et bottom des slots par rapport au group. Il Faut en mettre si ya des bouton +- forc<72>ment...
|
|||
|
rmargin="0"
|
|||
|
tmargin="0"
|
|||
|
bmargin="0"
|
|||
|
|
|||
|
list_sentence="" // Pour la magie Pointe vers un group de type="list_sentence". Utilise pour savoir
|
|||
|
// ou sont ajout<75>s les sentences nouvelles.
|
|||
|
|
|||
|
// Param<61>tres communs au ctrl type="sheet". Voir ce control pour les d<>tails
|
|||
|
|
|||
|
nature="" // la nature n est pas necessaire ici. C est FORCEMENT une "brick"
|
|||
|
tx_noitem=""
|
|||
|
onclick_l=""
|
|||
|
params_l=""
|
|||
|
onclick_r=""
|
|||
|
params_r=""
|
|||
|
dragable=""
|
|||
|
oncandrop=""
|
|||
|
params_candrop=""
|
|||
|
ondrop=""
|
|||
|
params_drop=""
|
|||
|
|
|||
|
/>
|
|||
|
|
|||
|
// Boutons pour changer le niveau de brick voulu
|
|||
|
|
|||
|
<ctrl type="button" id="add_level" button_type="push_button" posref="TR TR" tx_normal="W_arrow_up_3.tga" tx_pushed="W_arrow_up_3.tga" tx_over="W_button_08_over.tga" />
|
|||
|
<ctrl type="button" id="sub_level" button_type="push_button" posparent="add_row" posref="TL TR" tx_normal="W_arrow_down_3.tga" tx_pushed="W_arrow_down_3.tga" tx_over="W_button_08_over.tga" />
|
|||
|
|
|||
|
// vue qui affiche le niveau selectionn<6E>
|
|||
|
|
|||
|
<view type="text" id="view_level" />
|
|||
|
|
|||
|
// group de d<>coration qui affiche un fond derriere le texte (sert pour le scroll des levels <20> la molette)
|
|||
|
<group id="box_text" />
|
|||
|
</group>
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="select_number">
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
widget qui sert pour augmenter et diminuer un nombre de la database
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="select_number"
|
|||
|
value="" // lien vers la database. OBLIGATOIRE
|
|||
|
loop="true"
|
|||
|
min="0"
|
|||
|
max="9"
|
|||
|
/>
|
|||
|
<view type="text" id="number" /> // une vue qui permettra d'afficher le nombre
|
|||
|
<ctrl type="button" id="arrow_up" /> // boutton pour incr<63>menter
|
|||
|
<ctrl type="button" id="arrow_down" /> // boutton pour d<>cr<63>menter
|
|||
|
</group>
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="scroll_text">
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
widget servant <20> afficher des lignes de chat ou autres d<>filant, avec une scrollBar et des boutons pour augmenter
|
|||
|
la taille de la fenetre
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="scroll_text"
|
|||
|
min_height="16"
|
|||
|
max_height="128"
|
|||
|
invert_scroll_bar="true"
|
|||
|
>
|
|||
|
<ctrl type="scroll" id="scroll_bar"/>
|
|||
|
<ctrl type="button" id="button_add"/>
|
|||
|
<ctrl type="button" id="button_sub"/>
|
|||
|
<group type="list" id="text_list"/>
|
|||
|
</group>
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="editbox" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
edition de texte
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="edit_box"
|
|||
|
onenter="" // Action a lancer quand ENTER est press<73>
|
|||
|
params="" // param<61>tres de l Action a lancer quand ENTER est press<73>
|
|||
|
onchange=""
|
|||
|
onchange_params=""
|
|||
|
enter_loose_focus="true" // si enter perd le focus
|
|||
|
max_num_chars="oo" // chars maxi (infini par defaut)
|
|||
|
prompt=">"
|
|||
|
entry_type="" // text, integer, positive_integer, alpha, alpha_num, password
|
|||
|
menu_r=""
|
|||
|
max_historic="0" // Si !=0 enable l historique de l editBox (4Dos like). Sinon donne la taille de l historique
|
|||
|
>
|
|||
|
<view id="edit_text" type="text">
|
|||
|
</group>
|
|||
|
|
|||
|
MODIFIABLE: input_string (string)
|
|||
|
uc_input_string (ucstring)
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="build_sentence_magic" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Widget de composition de magie
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="build_sentence_magic" >
|
|||
|
// Brick racine
|
|||
|
<ctrl type="sheet" id="root_brick" nature="brick" />
|
|||
|
// Brick mandatory
|
|||
|
<vector template="ctrl_brick_mandatory" id="mandatory_brick$i" _size="%BRICKS_PER_SENTENCE" index="$i" />
|
|||
|
// Brick optional
|
|||
|
<vector template="ctrl_brick_optional" id="optional_brick$i" _size="%BRICKS_PER_SENTENCE" index="$i" />
|
|||
|
|
|||
|
// bouton de validation
|
|||
|
<ctrl type="button" id="valid_button" />
|
|||
|
</group>
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="build_sentence_faber" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Widget de composition de magie
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="build_sentence_faber" >
|
|||
|
// Brick racine
|
|||
|
<ctrl type="sheet" id="root_brick" nature="brick" />
|
|||
|
// Brick optional
|
|||
|
<vector template="ctrl_brick_optional" id="optional_brick$i" _size="%BRICKS_PER_SENTENCE" index="$i" />
|
|||
|
// bouton de validation
|
|||
|
<ctrl type="button" id="valid_button" />
|
|||
|
|
|||
|
// Tool
|
|||
|
<ctrl type="sheet" id="tool" nature="item" />
|
|||
|
// MPs
|
|||
|
<vector template="ctrl_faber_mp" id="mp$i" _size="%MAX_FABER_REQ_MP" index="$i" />
|
|||
|
// Select number
|
|||
|
<group type="select_number" id="select_num_items" value="bricks:faber:num_items" loop="false" min="1" max="1" >
|
|||
|
</group>
|
|||
|
</group>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="list_sentence" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Widget d'affichage des sentence connues. cf list_job pour le lien "list_sentence"
|
|||
|
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="list_sentence" id="pipo0"
|
|||
|
|
|||
|
wspace="2" hspace="2" // donne l espacement entre chaque slot. 0 par defaut
|
|||
|
|
|||
|
lmargin="12" // Marges left, right Top et bottom des slots par rapport au group. Defaut:0. Il Faut en mettre si ya une scrollBar et des bouton +- forc<72>ment...
|
|||
|
rmargin="2"
|
|||
|
tmargin="12"
|
|||
|
bmargin="2"
|
|||
|
|
|||
|
rowmin="0" // Nombre de ligne minium affich<63>es. Defaut: 1.
|
|||
|
// Important si on veut par exemple afficher la liste des malus vide sans que le groupe se resize <20> H=0 (vide)
|
|||
|
|
|||
|
rowmax="2" // Nombre de ligne maximum affich<63>s. Defaut: infini.
|
|||
|
// Important si on veut afficher qu une seule ligne toujours (pour les malus par exemple)
|
|||
|
// quelque soit la largeur du parent. C est cette valeur qui est <20>dit<69>e par les boutons +- (si pr<70>sents)
|
|||
|
|
|||
|
sep_slot0="" // Image pour le separateur Root-Mandatory
|
|||
|
sep_slot1="" // Image pour le separateur Mandatory-Optional
|
|||
|
sep_w0="0" // d<>calage Root-Mandatory
|
|||
|
sep_w1="0" // d<>calage Mandatory-Optional
|
|||
|
|
|||
|
selected_color="255 255 255 255" // couleur du highlight de la sentence selectionn<6E>e
|
|||
|
|
|||
|
// Param<61>tres communs au ctrl type="sheet". Voir ce control pour les d<>tails
|
|||
|
|
|||
|
nature="" // forc<72> en type brick
|
|||
|
tx_noitem=""
|
|||
|
onclick_l=""
|
|||
|
params_l=""
|
|||
|
onclick_r=""
|
|||
|
params_r=""
|
|||
|
dragable=""
|
|||
|
oncandrop=""
|
|||
|
params_candrop=""
|
|||
|
ondrop=""
|
|||
|
params_drop=""
|
|||
|
menu_l=""
|
|||
|
menu_r=""
|
|||
|
menu_b=""
|
|||
|
>
|
|||
|
|
|||
|
// Le mode "Resize" n'existe pas en fait. Le scripteur est libre de mettre ou pas une scroll bar et/ou des boutons qui permettent de changer rowmax
|
|||
|
|
|||
|
<ctrl type="button" id="add_row" button_type="push_button" posref="TR TR" tx_normal="W_arrow_up_3.tga" tx_pushed="W_arrow_up_3.tga" tx_over="W_button_08_over.tga" />
|
|||
|
<ctrl type="button" id="sub_row" button_type="push_button" posparent="add_row" posref="TL TR" tx_normal="W_arrow_down_3.tga" tx_pushed="W_arrow_down_3.tga" tx_over="W_button_08_over.tga" />
|
|||
|
|
|||
|
// Setup tyipque de scrollBar. L'alignement est hardoc<6F> pour etre Top. Le y devrait etre egal <20> "-tmargin" du group list_sheet
|
|||
|
|
|||
|
<ctrl type="scroll" id="scroll_row" posref="TL TL" w="8" x="2" y="12"
|
|||
|
<!-- choix des textures de la scroll -->
|
|||
|
tx_bottomleft= "w_scroll_l123_b.tga"
|
|||
|
tx_middle= "w_scroll_l123_m.tga"
|
|||
|
tx_topright= "w_scroll_l123_t.tga"
|
|||
|
|
|||
|
</group>
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="combo_box" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
affiche une combo_box. Un bouton sur un texte qui fait apparaitre un menu de selection de texte quand on clique dessus
|
|||
|
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<group type="combo_box"
|
|||
|
value="" // Valeur de la database qui indique l index de selection de la comboBox.
|
|||
|
on_select_start="" // optionnel. ActionHandler appel<65> apr<70>s ouverture des choix de la combo box
|
|||
|
>
|
|||
|
// Text qui affiche le choix courant.
|
|||
|
<view type="text" id="text" />
|
|||
|
// Boutton qui sert pour ouvrir la liste.
|
|||
|
<ctrl type="button" button_type="push_button" id="select" />
|
|||
|
// ajoute un choix pour la combo_box
|
|||
|
<combo_text name="" />
|
|||
|
</group>
|
|||
|
|
|||
|
Note: il faut que "ui:interface:combo_box_select_menu" soit d<>finie comme un <group type="menu"> avec
|
|||
|
les param<61>tres d'aspect que l'on veut. Les champs actions sont remplies quand la combo_box est ouverte
|
|||
|
|
|||
|
EXEMPLE:
|
|||
|
Ce setup permet de faire une combo box ou le bouton est invisible et recouvre en fait tout le group:
|
|||
|
si on clique sur le texte, on ouvre alors la liste de choix.
|
|||
|
|
|||
|
<group type="combo_box" id="combo1" w="100" h="18"
|
|||
|
value="UI:COMBO_SELECT1"
|
|||
|
>
|
|||
|
// un cadre juste pour faire joli
|
|||
|
<instance template="box_widget" id="back" sizeref="wh" w="0" h="0" />
|
|||
|
|
|||
|
// notre text
|
|||
|
<view type="text" id="text" posref="ML ML" x="2" />
|
|||
|
// Note pas de texture d<>finie sauf l'over: c fait expr<70>s.
|
|||
|
<ctrl type="button" button_type="push_button" id="select" sizeref="wh" w="0" h="0" col_over="255 255 255 128" tx_over="blank.tga" scale="true" />
|
|||
|
|
|||
|
<combo_text name="choix 1" />
|
|||
|
<combo_text name="choix 2" />
|
|||
|
<combo_text name="choix 3" />
|
|||
|
<combo_text name="choix 4" />
|
|||
|
|
|||
|
</group>
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="tree" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
h<EFBFBD>rite de group
|
|||
|
|
|||
|
BUT:
|
|||
|
affiche un arbre (comme un menu)
|
|||
|
|
|||
|
EXEMPLE:
|
|||
|
<group type="tree" id="pipo" col_over="255 255 255 128" col_select="255 128 128 128" fontsize="12" >
|
|||
|
<node id="invit" name="uimGcmInvit" handler="" params="" />
|
|||
|
<node id="harvest1" name="uimGcmHarvest" opened="true" >
|
|||
|
<node id="dig" name="uimGcmDigging"/>
|
|||
|
<node id="har" name="uimGcmHarvesting"/>
|
|||
|
</node>
|
|||
|
</group>
|
|||
|
|
|||
|
Sur les nodes qui contiennent des fils on peut setuper la valeur de d<>part <20> ouvert ou ferm<72>
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="html" />
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
<group type="html"
|
|||
|
error_color="255 0 0" // Error color
|
|||
|
link_color="128 128 255" // Link color
|
|||
|
text_color="255 255 255" // Text color
|
|||
|
h1_color="128 255 255" // Headline 1 color
|
|||
|
h2_color="255 128 255" // Headline 2 color
|
|||
|
h3_color="255 255 128" // Headline 3 color
|
|||
|
h4_color="255 255 255" // Headline 4 color
|
|||
|
h5_color="255 255 255" // Headline 5 color
|
|||
|
h6_color="255 255 255" // Headline 6 color
|
|||
|
error_color_global_color="false" // Error uses global color
|
|||
|
link_color_global_color="false" // Link uses global color
|
|||
|
text_color_global_color="false" // Text uses global color
|
|||
|
h1_color_global_color="false" // Headline 1 uses global color
|
|||
|
h2_color_global_color="false" // Headline 2 uses global color
|
|||
|
h3_color_global_color="false" // Headline 3 uses global color
|
|||
|
h4_color_global_color="false" // Headline 4 uses global color
|
|||
|
h5_color_global_color="false" // Headline 5 uses global color
|
|||
|
h6_color_global_color="false" // Headline 6 uses global color
|
|||
|
text_font_size="12" // Text font size
|
|||
|
h1_font_size="24" // Headline 1 font size
|
|||
|
h2_font_size="20" // Headline 2 font size
|
|||
|
h3_font_size="16" // Headline 3 font size
|
|||
|
h4_font_size="16" // Headline 4 font size
|
|||
|
h5_font_size="16" // Headline 5 font size
|
|||
|
h6_font_size="16" // Headline 6 font size
|
|||
|
paragraph_begin_space="12" // Space between paragraphs
|
|||
|
multi_line_space_factor="0.25" // Space between 2 lines of a paragraph. Factor of the font size
|
|||
|
td_begin_space="0" // Space at the begining of a table cell
|
|||
|
li_begin_space="4" // H space when "<IL>"
|
|||
|
ul_begin_space="12" // H space when "<UL>"
|
|||
|
li_indent="-10" // W space when "<LI>"
|
|||
|
ul_indent="30" // W space when "<UL>"
|
|||
|
form_text_area_group="edit_box_widget" // The group to instanciate for a form edit box. It must have a child group CGroupEditBox* with the id "eb"
|
|||
|
checkbox_bitmap_normal="checkbox_normal.tga" // The "off" bitmap use in form checkbox
|
|||
|
checkbox_bitmap_pushed="checkbox_pushed.tga" // The "on" bitmap use in form checkbox
|
|||
|
checkbox_bitmap_over="checkbox_over.tga" // The "over" bitmap use in form checkbox
|
|||
|
background_bitmap_view="bg" // The name of the child bitmap view used for background
|
|||
|
home="http://www.nevrax.org" // The home url (you can browsse to the home url with the url "home"
|
|||
|
browse_next_time="false" // If true, the url is browsed when the group is created
|
|||
|
>
|
|||
|
</group>
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="quick_help" /> (derived from HTML)
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
<group type="quick_help"
|
|||
|
non_selected_color="255 0 0" // The unselected paragraphes color
|
|||
|
non_selected_link_color"0 0 128" // The unselected link color
|
|||
|
non_selected_global_color="true" // The unselected paragraphes uses gobal color
|
|||
|
non_selected_font_size="10" // The unselected paragraphes font size
|
|||
|
>
|
|||
|
</group>
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="in_scene" /> (derived from group)
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
<group type="in_scene"
|
|||
|
in_scene_offset_x="12" // Offset in pixels
|
|||
|
in_scene_offset_y="12" // Offset in pixels
|
|||
|
>
|
|||
|
</group>
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <group type="table" /> (derived from group)
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
a html-like table :
|
|||
|
|
|||
|
The table is essentially an array. Each line must have the same number of cells.
|
|||
|
The width of the table can be arbitrary. Either sizeref="w" or a fixed w can be used.
|
|||
|
using child_resize_w has undefined results.
|
|||
|
The height or the table is imposed by its children cells (like with html table)
|
|||
|
|
|||
|
Table is specified using the standard <TR> & <TD>
|
|||
|
|
|||
|
// option for the table :
|
|||
|
border : the same the html tables 'border'
|
|||
|
cellpadding : the same the html tables 'cellpadding'
|
|||
|
cellspacing : the same the html tables 'cellspacing'
|
|||
|
bgcolor : background color with format "R G B A" ("255 0 0 255" for example)
|
|||
|
width : wanted width of table in pixels (same than html "width"). could be a ratio like "100%"
|
|||
|
usually the table will specify sizeref="w" or w and width="100%"
|
|||
|
continuous_update : whan set to true, the table will be updated continuously has its parent container is resized, and not when mouse left button is released only
|
|||
|
|
|||
|
// options for the cells (<TD> tag)
|
|||
|
Cells can have an id. If none is given a id like cell_1_2 id generated (first number is column, second is row)
|
|||
|
align : horizontal alignment of cell content. Can be "left", "right" or "center" (same than HTML 'align')
|
|||
|
valign : vertical alignment of cell content. Can be 'top", "middle" or "bottom" (same than HTML 'valign')
|
|||
|
left_margin : offset added to the x position of the cell content
|
|||
|
nowrap : same then htlm table 'nowrap'
|
|||
|
bgcolor : color of the cell background (with the "R G B A" format)
|
|||
|
width : same then htlm table 'width' : gives width of column for that cell, or a percentage
|
|||
|
add_child_w : take the wanted size from the size of the children (equivalent to child_resize_h), and add the 'width' (not added if a percentage)
|
|||
|
height : minimum height of the cell
|
|||
|
ignore_max_width : if "true", the cell content max_used_w is ignored when computing the width of the cell
|
|||
|
ignore_min_width : if "true", the cell content min_used_w is ignored when computing the width of the cell
|
|||
|
|
|||
|
|
|||
|
|
|||
|
<group type="table" id="my_table" posref="TL TL" sizeref="w" width="100%" border="2" bgcolor="0 255 0 255" y="-4"
|
|||
|
cellspacing="1"
|
|||
|
cellpadding="0"
|
|||
|
continuous_update="true"
|
|||
|
>
|
|||
|
<!-- test 1 -->
|
|||
|
<TR>
|
|||
|
<TD width="30%" bgcolor="0 0 0 127" height="30" align="center" valign="middle" id="optionnal_id">
|
|||
|
<view type="text" id="mon_text" global_color="true" fontsize="20" shadow="true" hardtext="cell 1 cell 1 cell 1 cell 1"
|
|||
|
multi_line="true"
|
|||
|
/>
|
|||
|
</TD>
|
|||
|
<TD bgcolor="255 0 0 127" height="30" align="center" valign="middle">
|
|||
|
<view type="text" id="mon_text" global_color="true" fontsize="20" shadow="true" hardtext="cell 2"/>
|
|||
|
</TD>
|
|||
|
</TR>
|
|||
|
<TR>
|
|||
|
<TD width="30%" bgcolor="0 0 0 192" height="30" align="center" valign="middle">
|
|||
|
<view type="text" id="mon_text" global_color="true" fontsize="20" shadow="true" hardtext="cell 3"/>
|
|||
|
</TD>
|
|||
|
<TD bgcolor="0 0 255 192" height="30" align="center" valign="middle">
|
|||
|
<view type="text" id="mon_text" global_color="true" fontsize="20" shadow="true" hardtext="cell 4"/>
|
|||
|
</TD>
|
|||
|
</TR>
|
|||
|
<!--
|
|||
|
<TR>
|
|||
|
<TD width="100%" bgcolor="255 0 0 127" height="30">
|
|||
|
<view type="text" posref="TL TL" global_color="true" fontsize="20" shadow="true" hardtext="cell 2"/>
|
|||
|
</TD>
|
|||
|
</TR>
|
|||
|
-->
|
|||
|
</group>
|
|||
|
</group>
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
// MISC: DEFINE, PROCEDURES, TEMPLATES, ANIM, SCENE3D, ...
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <define>
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Permet de definir une constante.
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<define id="id_du_define" value="valeur_a_remplacer" />
|
|||
|
|
|||
|
EXAMPLE:
|
|||
|
<define id="pipo_title" value="yoyo" />
|
|||
|
....
|
|||
|
<group type="container" id="player" title="Hello %pipo_title" >
|
|||
|
|
|||
|
|
|||
|
Comme ca "Hello %pipo_title" est remplac<61> par "Hello yoyo"
|
|||
|
|
|||
|
L'id du define ne peut contenir que les charact<63>res:
|
|||
|
'a' <20> 'z'
|
|||
|
'A' <20> 'Z'
|
|||
|
'0' <20> '9'
|
|||
|
'_'
|
|||
|
|
|||
|
|
|||
|
Du coup si vous voulez vraiment afficher un % dans une string (par exemple "25 %"), il faut l'ecrire en double "25 %%"
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <proc>
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Definit un action handler special qui lance des action handlers <20> la suite
|
|||
|
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<proc id="nom_procedure" >
|
|||
|
<action handler="action_handler0" params="" />
|
|||
|
<action handler="action_handler1" params="" />
|
|||
|
<action handler="action_handler2" params="@0|@1" />
|
|||
|
</proc>
|
|||
|
|
|||
|
les param<61>tres sont optionnels.
|
|||
|
un action handler peut etre lui meme une autre procedure (attention recursivit<69> :))
|
|||
|
|
|||
|
La proc<6F>dure se lance en utilisant l'action handler "proc" avec comme param<61>tre "nom_procedure"
|
|||
|
|
|||
|
La proc<6F>dure peut prendre des param<61>tres en entr<74>e (voir l'action handler proc pour comment faire).
|
|||
|
Pour chaque action, le champ params="" est pars<72>. Tout chaine de type @#, ou # est un num<75>ro
|
|||
|
(<28> N chiffres) copiera alors le param<61>tre (simple copie de chaine) au moment de l'appel.
|
|||
|
|
|||
|
Note: de la m<>me facon que les % dans les define, un double @ permet de ne pas consid<69>rer l'@ comme un descripteur
|
|||
|
de param<61>tre
|
|||
|
|
|||
|
EXAMPLE:
|
|||
|
<proc id="select_quit_modal" >
|
|||
|
<action handler="exchange" params="src=ctrl_launch_modal" />
|
|||
|
<action handler="leave_modal" />
|
|||
|
</proc>
|
|||
|
|
|||
|
....
|
|||
|
|
|||
|
<ctrl type="button" onclick_l="proc" params_l="select_quit_modal">
|
|||
|
|
|||
|
|
|||
|
EXAMPLE param<61>tres:
|
|||
|
<proc id="set_quit_modal" >
|
|||
|
<action handler="set" params="dblink=SERVER:PIPO|value=@0" />
|
|||
|
<action handler="leave_modal" />
|
|||
|
</proc>
|
|||
|
|
|||
|
....
|
|||
|
|
|||
|
<ctrl type="button" onclick_l="proc" params_l="set_quit_modal|10">
|
|||
|
|
|||
|
Dans cet exemple, sur un cliok gauche du bouton, set sera appel<65> avec une valeur de 10!!
|
|||
|
Notez que l'index des param<61>tres commence <20> 0.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <template>
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Definit un patron qui permet d'instancier des groups, ctrls ou vues qui se ressemblent.
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
Definition du template:
|
|||
|
<template name="nom_du_template" ...param<61>tres du template...>
|
|||
|
corps du template (group, controls etc...) qui reference les param<61>tres du template avec #
|
|||
|
</template>
|
|||
|
|
|||
|
Instanciation du template:
|
|||
|
<instance template="nom_du_template" param<61>tres du template remplis />
|
|||
|
|
|||
|
EXAMPLE:
|
|||
|
<!--Definit un template de nom "SNH" qui attend des param<61>tres id, value, loop etc... (si "" est mis <20> un param<61>tres,
|
|||
|
celui-ci doit etre d<>fini <20> l'instanciation)
|
|||
|
-->
|
|||
|
<template name="SNH" id="" value="" loop="true" min="0" max="9" posparent="parent" posref="MM MM" x="0" y="0" w="26" h="16" >
|
|||
|
<group type="select_number" id="#id" value="#value" loop="#loop" min="#min" max="#max" x="#x" y="#y" w="#w" h="#h" posparent="#posparent" posref="#posref" >
|
|||
|
<view type="bitmap" id="slot_number" posref="TL TL" texture="W_slot_number.tga" />
|
|||
|
<view type="text" id="number" posparent="slot_number" posref="MM MM" color="255 255 255 255" fontsize="12" shadow="true" hardtext="0" />
|
|||
|
<ctrl type="button" id="arrow_up" button_type="push_button" posref="TR TR" tx_normal="W_arrow_up_3.tga" tx_pushed="W_arrow_up_3.tga" tx_over="W_button_08_over.tga" />
|
|||
|
<ctrl type="button" id="arrow_down" button_type="push_button" posref="BR BR" tx_normal="W_arrow_down_3.tga" tx_pushed="W_arrow_down_3.tga" tx_over="W_button_08_over.tga" />
|
|||
|
</group>
|
|||
|
</template>
|
|||
|
|
|||
|
<!--Instancie le template SNH
|
|||
|
-->
|
|||
|
<instance template="SNH" id="shortnumber" value="SERVER:USER:SAP" loop="true" min="0" max="9" posref="ML ML" />
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <vector>
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
Create an array of template's instances (mutli instance version of <instance>)
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<vector
|
|||
|
template="template_name" // as in <instance....
|
|||
|
_size="" // required. number of isntance to create
|
|||
|
_firstindex="0" // optional to begin the index of instance to a number!=0
|
|||
|
|
|||
|
// Next ones are required only if the template is a serie of interface elements (group, view....)
|
|||
|
// that need to be sticked against each other (eg: a vertical array of view text)
|
|||
|
_firstpos="" // posref (TL TL...) of the first element, sticked to the parent
|
|||
|
_nextpos="" // posref (TR TL...) of next elements, sticked to the previous one
|
|||
|
_xfirst="" // special x of the first element
|
|||
|
_yfirst="" // special y of the first element
|
|||
|
/>
|
|||
|
|
|||
|
Then for each instance created, All properties of the XML node are parsed, and $i are replaced with the index of the instance
|
|||
|
|
|||
|
EXAMPLE:
|
|||
|
<template name="temp_tab" keep="true" nb="" id="" posparent="" posref="" x="" >
|
|||
|
<ctrl style="tab_button_new" id="#id" posparent="#posparent" posref="#posref"
|
|||
|
group="content:group#nb" text="TabNo#nb" />
|
|||
|
</template>
|
|||
|
|
|||
|
<vector template="temp_tab" _size="16" _firstpos="TR TL" _nextpos="TR TL" _xfirst="4" x="1" id="tab_array0_$i" nb="$i" posparent="tabref" />
|
|||
|
|
|||
|
This will create 16 instances of ctrls (tab_array0_0, tab_array0_1, tab_array0_2....)
|
|||
|
The first one will be placed on right of "tabref", but with a x of 4 (_firstpos="TR TL" _xfirst="4")
|
|||
|
The next ones will be placed on right of each other, but sticked with a x of 1 (_nextpos="TR TL" x="1" )
|
|||
|
|
|||
|
NB: if '_xfirst' is not defined, then 'x' will be taken for the first position also
|
|||
|
NB: if '_yfirst' is not defined, then 'y' will be taken for the first position also
|
|||
|
NB: Both _firstpos/_nextpos must be defined in order for the "stick system" to work
|
|||
|
also you must declare id="", posparent="" and posref="" in the template definition.
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <variable>
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
BUT:
|
|||
|
cr<EFBFBD>e une variable et associe une valeur
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
<variable
|
|||
|
entry="" // Obligatoire. lien vers la database.
|
|||
|
type="" // Obligatoire. sint32, sint64, float, double, bool, rgba, hotspot.
|
|||
|
// float et double on le meme effet
|
|||
|
value="" // valeur <20> mettre
|
|||
|
size="" // Si d<>finit, alors <variable> sert <20> d<>finir un tableau.
|
|||
|
/>
|
|||
|
|
|||
|
EXAMPLE:
|
|||
|
<variable entry="UI:MODE" type="sint32" value="0"/>
|
|||
|
|
|||
|
Dans le cas de d<>finition d'un tableau, le premier "$i" rencontr<74> est remplac<61> par l'index de 0 <20> size-1.
|
|||
|
<variable entry="UI:LIST:$i:SHEET" type="sint32" value="0" size="4" />
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <link>
|
|||
|
// ***************************************************************************
|
|||
|
BUT:
|
|||
|
li<EFBFBD> une expression <20> une valeur d'une vue (target). L'expression doit dependre d'entr<74>e de la database. A chaque fois qu'une
|
|||
|
entr<EFBFBD>e de la database est updat<61>e, l'expression est recalcul<75>e, et le target est updat<61>e.
|
|||
|
|
|||
|
SYNTAXE:
|
|||
|
|
|||
|
<link
|
|||
|
expr="" // obligatoire : expression a <20>valuer. L'expression doit d<>pendre au moins d'une entr<74>e de la database
|
|||
|
target="" // valeurs auxquelles doit etre affect<63>e le r<>sultat de l expression, relatif au groupe qui contient le link, ou consid<69>r<EFBFBD> comme une adresse absolue si non trouv<75>
|
|||
|
action="" // facultatif : un action handler a appeller en cas d update
|
|||
|
params="" // facultatif : param<61>tre pour l action handler
|
|||
|
cond="" // facultatif : condition <20> l'execution de l'action handler
|
|||
|
/>
|
|||
|
|
|||
|
EXAMPLE:
|
|||
|
|
|||
|
<view type="bitmap" id="my_view" >
|
|||
|
<link expr="ne(@my_db_entry, 0)" target="my_view:active,my_other_view:active"/> // si l entr<74>e de database 'my_db_view' ne vaut pas 0, alors my_view:active est mis <20> true
|
|||
|
|
|||
|
CREATION DYNAMIQUE DE LIEN:
|
|||
|
Elle est utile si on veut que les update ne soient pris en compte qu'<27> un moment pr<70>cis (par exemple dans une boite modale)
|
|||
|
C'est sutout bien dans le cas de test couteux ou si des textes non visibles sont updat<61>s pour rien.
|
|||
|
|
|||
|
// cr<63>ation :
|
|||
|
handler="add_link" params="id=identifier_unique|expr=expression_a_evaluer|target=dest_de_lexpression"
|
|||
|
|
|||
|
// supression:
|
|||
|
handler="remove_link" params="id=identifier_unique|expr=expression_a_evaluer|target=dest_de_lexpression"
|
|||
|
|
|||
|
|
|||
|
par exemple, en reprenant l exemple precedent:
|
|||
|
|
|||
|
handler="add_link" params="id=mon_lien|expr=ne(@my_db_entry, 0)|target=my_view:active"
|
|||
|
handler="remove_link" params="id=mon_lien"
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <anim> <track> <key>
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
<anim
|
|||
|
id="specie_in" // nom du timer
|
|||
|
duration="3.0" // temps en seconde pour faire varier l entree dans la database
|
|||
|
loop="true" // est ce que l anim doit boucler ?
|
|||
|
reverse="false" // est ce que l anim doit etre jouee a l envers
|
|||
|
on_finish="ahwhenfini" // action handler a lancer quand le timer arrive a la fin
|
|||
|
on_finish_params="ahp" // les parametres de l action handler
|
|||
|
/>
|
|||
|
|
|||
|
<track
|
|||
|
type="linear" // linear, bezier, tcb
|
|||
|
target="specie:race:y" // all the targets affected may be more than one
|
|||
|
dynamic="true" // (def:false) si true evalue tous les parametres des cles lors du lancement de l anim
|
|||
|
/>
|
|||
|
|
|||
|
Si la track est de type linear :
|
|||
|
<key
|
|||
|
time="1.0" // Une valeur de temps comprise entre 0 et la duration de l anim
|
|||
|
value="15" // la valeur que prennent les targets au temps : time
|
|||
|
/>
|
|||
|
|
|||
|
Si la track est de type bezier :
|
|||
|
<key
|
|||
|
time="1.0" // Une valeur de temps comprise entre 0 et la duration de l anim
|
|||
|
value="15" // la valeur que prennent les targets au temps : time
|
|||
|
intan="0.0" // float facultatif def:0 ???? aucune idee de ce a quoi ca peut servir
|
|||
|
outtan="0.0" // float facultatif def:0 ???? aucune idee de ce a quoi ca peut servir
|
|||
|
step="true" // bool facultatif def:false ???? aucune idee de ce a quoi ca peut servir
|
|||
|
/>
|
|||
|
|
|||
|
Si la track est de type TCB :
|
|||
|
<key
|
|||
|
time="1.0" // Une valeur de temps comprise entre 0 et la duration de l anim
|
|||
|
value="15" // la valeur que prennent les targets au temps : time
|
|||
|
tension="1.0" // float facultatif def:0
|
|||
|
continuity="0.0" // float facultatif def:0
|
|||
|
bias="1.0" // float facultatif def:0
|
|||
|
easeto="0.1" // float facultatif def:0
|
|||
|
easefrom="0.3" // float facultatif def:0
|
|||
|
/>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
un exemple typique est :
|
|||
|
|
|||
|
<group id="specie" sizeref="wh" on_active="anim_start" on_active_params="anim=t1">
|
|||
|
<group id="race" posref="BL BL" x="16" y="64">
|
|||
|
</group>
|
|||
|
</group>
|
|||
|
|
|||
|
<anim id ="t1" duration="3.0" >
|
|||
|
<track type="linear" target="specie:race:y">
|
|||
|
<key time="0.0" value="-16"/>
|
|||
|
<key time="3.0" value="64"/>
|
|||
|
</track>
|
|||
|
</anim>
|
|||
|
|
|||
|
quand on va activer le groupe specie cela va lancer l'animation t1. la valeur
|
|||
|
specie:race:y va etre modifiee -> cela va faire monter le groupe specie:race
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <scene3d> <character3d> <ig> <camera> <light>
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
// ---------------------------------------------------------------------------
|
|||
|
<scene3d
|
|||
|
reference="id_scene3d" // Donne la reference sur une autre scene 3d (dans ce cas la c est juste une vue sur une autre scene)
|
|||
|
ambient="0 0 0"
|
|||
|
sun_ambient="50 50 50"
|
|||
|
sun_diffuse="255 255 255"
|
|||
|
sun_specular="255 255 255"
|
|||
|
sun_direction="-1.0 1.0 -1.0"
|
|||
|
curcam="id_camera" // Camera courante
|
|||
|
curcs="id_camera" // Cluster system courant (un ig avec des clusters)
|
|||
|
|
|||
|
user_interaction="true" // Interaction camera (qui doit etre call<6C>e en y (ie camx=tgtx & camz=tgtz)
|
|||
|
rotz_factor="0.005" // Facteur de vitesse lors d une rotation autour
|
|||
|
rotz_limit_min="-45" // Limites d angles
|
|||
|
rotz_limit_max="45"
|
|||
|
roty_factor="0.005" // Facteur de vitesse lors d une rotation haut-bas
|
|||
|
roty_limit_min="-20"
|
|||
|
roty_limit_max="20"
|
|||
|
dist_factor="0.005" // Facteur de vitesse lors d un deplacement de distance
|
|||
|
dist_limit_min="0.1" // Limites de distances en metres
|
|||
|
dist_limit_max="20"
|
|||
|
|
|||
|
/>
|
|||
|
|
|||
|
DERIVANT DE <group>
|
|||
|
|
|||
|
MODIFIABLE: curcam (string)
|
|||
|
curcs (string)
|
|||
|
rotzfactor (float)
|
|||
|
|
|||
|
// ---------------------------------------------------------------------------
|
|||
|
<character3d
|
|||
|
dblink="UI:TEMP:CHAR3D"
|
|||
|
pos="1.0 2.0 3.0"
|
|||
|
rot="0.0 0.0 90.0"
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: headx, heady, headz (float la position de la tete apres au moins une frame d animation)
|
|||
|
posx, posy, posz (float la position)
|
|||
|
rotx, roty, rotz (float angle en degres)
|
|||
|
anim (int)
|
|||
|
|
|||
|
// ---------------------------------------------------------------------------
|
|||
|
<ig
|
|||
|
name="ig_name.ig"
|
|||
|
pos="1.0 2.0 3.0"
|
|||
|
rot="1.0 2.0 3.0"
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: posx, posy, posz (float la position)
|
|||
|
posx, posy, posz (float l orientation en degree)
|
|||
|
name (string)
|
|||
|
|
|||
|
// ---------------------------------------------------------------------------
|
|||
|
<shape
|
|||
|
name="shape_name.shape"
|
|||
|
pos="1.0 2.0 3.0"
|
|||
|
rot="1.0 2.0 3.0"
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: posx, posy, posz (float la position)
|
|||
|
posx, posy, posz (float l orientation en degree)
|
|||
|
name (string)
|
|||
|
|
|||
|
// ---------------------------------------------------------------------------
|
|||
|
<camera
|
|||
|
pos="1.0 2.0 3.0"
|
|||
|
target="2.0 3.0 4.0"
|
|||
|
fov="50.0"
|
|||
|
roll="0.0"
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: posx, posy, posz (float la position)
|
|||
|
tgtx, tgty, tgtz (float la position de la target)
|
|||
|
fov (float angle en degree)
|
|||
|
roll (float angle en degree)
|
|||
|
|
|||
|
// ---------------------------------------------------------------------------
|
|||
|
<light
|
|||
|
pos="1.0 2.0 3.0"
|
|||
|
near="3.0"
|
|||
|
far="10.0"
|
|||
|
color="127 255 64 255"
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: posx, posy, posz (float la position)
|
|||
|
near, far (float)
|
|||
|
colr, colg, colb (int)
|
|||
|
|
|||
|
// ---------------------------------------------------------------------------
|
|||
|
<fx
|
|||
|
name="sp_cast_loop.ps"
|
|||
|
pos="1.0 2.0 3.0"
|
|||
|
rot="0.0 0.0 0.0"
|
|||
|
/>
|
|||
|
|
|||
|
MODIFIABLE: posx, posy, posz (float la position)
|
|||
|
rotx, roty, rotz (float la rotation)
|
|||
|
started (bool le fx est il en train d etre joue ?)
|
|||
|
|
|||
|
|
|||
|
un exemple typique :
|
|||
|
|
|||
|
<scene3d id="char3d" x="576" y="-32" w="576" h="488" posref="TR TR" curcam="cam"
|
|||
|
ambient="0 0 0" sun_ambient="50 50 50" sun_diffuse="255 255 255" sun_specular="255 255 255" sun_direction="-1.0 1.0 -1.0" >
|
|||
|
|
|||
|
<character3d id="char" dblink="UI:TEMP:CHAR3D" pos="0.07 26.52 0.85" rot="0.0 0.0 -90.0" />
|
|||
|
|
|||
|
<camera id="cam" fov="45" pos="0.01 22.29 2.5" target="0.01 37.9 1.53" roll="0" />
|
|||
|
|
|||
|
<light id="l1" pos="-1.0 24.29 2.0" color="0 255 0" near="1.0" far="5.0" />
|
|||
|
|
|||
|
<ig id="env" name="matis.ig" pos="0 0 0" />
|
|||
|
|
|||
|
<fx id="fx1" pos="0.0 0.0 0.0" name="Sp_Cast_Loop.ps" />
|
|||
|
|
|||
|
</scene3d>
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <action_category >
|
|||
|
// <action>
|
|||
|
// <parameter>
|
|||
|
// <value>
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
// Definition d'une category d'action
|
|||
|
<action_category
|
|||
|
hardtext="uiUI" // Nom de la category localis<69> (defaut : "")
|
|||
|
/>
|
|||
|
|
|||
|
// ---------------------------------------------------------------------------
|
|||
|
|
|||
|
// Une definition d'action de base
|
|||
|
<action
|
|||
|
repeat="0" // 1 : l'action est r<>p<EFBFBD>t<EFBFBD>e avec la r<>p<EFBFBD>tition clavier, 0 : elle n'est pas r<>p<EFBFBD>t<EFBFBD>e. (defaut : 0)
|
|||
|
name="screenshot" // Nom de l'action handler utilis<69> par l'action (defaut : "")
|
|||
|
hardtext="uiTakeScreenshot" // Nom localis<69> de l'action (defaut : "")
|
|||
|
/>
|
|||
|
|
|||
|
// ---------------------------------------------------------------------------
|
|||
|
|
|||
|
// Un param<61>tre d'action de base
|
|||
|
<parameter
|
|||
|
type="action_param_constant" // Type de param<61>tre :
|
|||
|
// action_param_hidden : le param<61>tre est cach<63> <20> l'utillisateur
|
|||
|
// action_param_constant : le param<61>tre est une valeur pr<70>d<EFBFBD>termin<69>e (voir <value>)
|
|||
|
// action_param_user : le param<61>tre est entr<74> par l'utilisateur. Tous les characters sont permis.
|
|||
|
// action_param_user_name : le param<61>tre est entr<74> par l'utilisateur. Uniquement les characters permis dans les noms sont utilis<69>s.
|
|||
|
// (defaut : action_param_constant)
|
|||
|
name="filename" // Nom du param<61>tre (defaut : "")
|
|||
|
hardtext="uiFilename" // Nom localis<69> du param<61>tre (defaut : "")
|
|||
|
value="" // La valeur par defaut du param<61>tre (defaut : "")
|
|||
|
/>
|
|||
|
|
|||
|
// ---------------------------------------------------------------------------
|
|||
|
|
|||
|
// Une valeur pr<70>d<EFBFBD>finie de param<61>tre d'action de base
|
|||
|
<value
|
|||
|
value="toto" // La valeur (defaut : "")
|
|||
|
hardtext="uiToto" // Le nom localis<69> de la valeur (defaut : "")
|
|||
|
>
|
|||
|
|
|||
|
Exemple :
|
|||
|
|
|||
|
<action_category hardtext="uiDivers">
|
|||
|
|
|||
|
// Action pour envoyer un message <20> un joueur
|
|||
|
<action repeat="0" name="tell" hardText="uiTell">
|
|||
|
<parameter type="action_param_user_name" name="user" hardText="uiUsername" visible="1"/>
|
|||
|
<parameter type="action_param_user" name="message" hardText="uiMessage" visible="1"/>
|
|||
|
</action>
|
|||
|
|
|||
|
// Action pour passer en mode labo
|
|||
|
<action name="set_mode" hardText="uiModelabo">
|
|||
|
<parameter value="2" visible="0"/>
|
|||
|
</action>
|
|||
|
|
|||
|
// Action pour ouvrir un inventaire de sac
|
|||
|
<action repeat="0" name="open_window" hardText="uiOpenWindow">
|
|||
|
<parameter type="action_param_constant" name="" hardText="uiWindow" visible="1">
|
|||
|
<value value="UI:BAG1" hardtext="uiBag1"/>
|
|||
|
<value value="UI:BAG2" hardtext="uiBag2"/>
|
|||
|
<value value="UI:BAG3" hardtext="uiBag3"/>
|
|||
|
</parameter>
|
|||
|
</action>
|
|||
|
|
|||
|
</action_category>
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// <key>
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
<key name="Key1" ctrl="0" shift="0" menu="0" action="run_shortcut" params="1"/>
|
|||
|
|
|||
|
Bind a key combo to an action handler.
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
// ACTIONS
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
|
|||
|
<action="enter_modal" params="group=ui:interface:yoyo_modal1">
|
|||
|
affiche la fenetre modal ui:interface:yoyo_modal1 ici.
|
|||
|
|
|||
|
<action="leave_modal">
|
|||
|
cache la fenetre modal courante
|
|||
|
|
|||
|
<action="proc" params="nom_procedure|arg0|arg1|...">
|
|||
|
lance une proc<6F>dure. Les arguments sont s<>par<61>s du nom de la proc<6F>dure par des "|".
|
|||
|
|
|||
|
<action="set" params="dblink=liendatabase|value=expr">
|
|||
|
set un sint32, resultat de l'evaluation de expr, dans la database.
|
|||
|
|
|||
|
<action="set" params="target_property=target0,target1,...,targetn|value=expr">
|
|||
|
affecte le resultat de l'evaluation de expr a chacun des target (valeur export<72>e des elements de l'interface telle que 'active')
|
|||
|
|
|||
|
<action="copy" params="dbdst=liendatabase|dbsrc=liendatabase">
|
|||
|
copie une valeur de la database dans une autre
|
|||
|
|
|||
|
<oncandrop="isitem" params="">
|
|||
|
test si dropable est un item
|
|||
|
|
|||
|
<oncandrop="isitem_slot" params="type=itemslot">
|
|||
|
test si dropable est un item d'un certain type (HEAD, ARMS...)
|
|||
|
|
|||
|
<onfilter="filter_item" params_filter="type=itemslot">
|
|||
|
test si le ctrlSheet est un item d'un certain type (HEAD, ARMS...)
|
|||
|
<EFBFBD> mettre sur les props de list_sheet
|
|||
|
|
|||
|
<action="set_keyboard_focus" params="target=ui:interface_my_edit_box|select_all=true">
|
|||
|
Met le focus sur l'edit box en target. Selectionne tout le texte si select_all vaut true
|
|||
|
|
|||
|
<on_active="timer_start" on_active_params="timer=specie_in">
|
|||
|
Lance un timer (voir <timer>)
|
|||
|
|
|||
|
|
|||
|
<action="set_server_id" params="value=@%user_name_id|target=player_name:uc_hardtext">
|
|||
|
Affecte une value a une target. La value represente un identifiant de mot reseau (nom des jouers par exemple)
|
|||
|
|
|||
|
<action="set_server_string" params="value=@%user_name_id|target=player_name:uc_hardtext">
|
|||
|
Affecte une value a une target. La value represente un identifiant de chaine reseau (phrase composee de plusieurs mots)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
// COMMON EXPRESSIONS
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
add
|
|||
|
arguments : 2
|
|||
|
return (arg1 + arg2)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
sub
|
|||
|
arguments : 2
|
|||
|
return (arg1 - arg2)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
mul
|
|||
|
arguments : 2
|
|||
|
return (arg1 * arg2)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
div
|
|||
|
arguments : 2
|
|||
|
return (arg1 / arg2)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
mod
|
|||
|
arguments : 2
|
|||
|
return (arg1 % arg2)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
abs
|
|||
|
arguments : 1
|
|||
|
return abs(arg1) (valeur absolue de arg1)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
identity
|
|||
|
arguments : 1
|
|||
|
return (arg1)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
ne
|
|||
|
arguments : 2
|
|||
|
return (arg1 != arg2)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
eq
|
|||
|
arguments : 2
|
|||
|
return (arg1 == arg2)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
lt
|
|||
|
arguments : 2
|
|||
|
return (arg1 < arg2)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
le
|
|||
|
arguments : 2
|
|||
|
return (arg1 <= arg2)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
gt
|
|||
|
arguments : 2
|
|||
|
return (arg1 > arg2)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
ge
|
|||
|
arguments : 2
|
|||
|
return (arg1 >= arg2)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
or
|
|||
|
arguments : n > 0
|
|||
|
return (arg1 || arg2 || ... || argn)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
and
|
|||
|
arguments : n > 0
|
|||
|
return (arg1 && arg2 && ... && argn)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
not
|
|||
|
arguments : 1
|
|||
|
return (!arg0)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
str
|
|||
|
arguments : n > 0
|
|||
|
converti tous les arguments en string et return arg1_str + arg2_str + ... + argn_str
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
int
|
|||
|
arguments : 1
|
|||
|
converti l'argument en entier
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
ifthenelse
|
|||
|
arguments : 2 ou 3 (1er argument de type bool)
|
|||
|
retourne le 2eme argument si le 1er est vrai
|
|||
|
sinon retourne le 3eme argument (si il existe)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
switch
|
|||
|
arguments : au moins 2 (1er argument de type int)
|
|||
|
retourne le n ieme argument ou n est la valeur du premier argument +1
|
|||
|
si arg1 vaut 0 on retourne arg2
|
|||
|
si arg1 vaut 1 on retourne arg3
|
|||
|
et ainsi de suite
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
ilinear
|
|||
|
arguments : 3 double (1er == interpolant (0 - 1.0)) (a 0 arg2 max, a 1 arg3 max)
|
|||
|
retourne arg2 + arg1 * (arg3 - arg2)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getbit
|
|||
|
arguments : 2 entiers (1er == valeur, 2nd == numero du bit desire)
|
|||
|
retourne le arg2_ieme bits de la valeur arg1
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
rand
|
|||
|
arguments : 2 double
|
|||
|
retourne une valeur comprise entre arg1 et arg2
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
dbcount
|
|||
|
arguments : 1 (string) (exemple : dbcount('SERVER:MODIFIERS:BONUS:$:SHEET')
|
|||
|
compte le nombre d occurences dans la database.
|
|||
|
si l entree est un noeud alors detecte qu il ne soit pas egal a zero
|
|||
|
il faut obligatoirement un $ (qui sera remplace par 0,1,2,...)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getprop
|
|||
|
arguments : 1 (string) (exemple : getprop('ui:interface:define_day_color:pick:b'))
|
|||
|
retourne la valeur MODIFIABLE d un element d interface
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
intToColor
|
|||
|
arguments : 1 (integer)
|
|||
|
retourne la meme valeur en rgba
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getRed
|
|||
|
arguments : 1 (rgba)
|
|||
|
retourne la meme valeur du rouge
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getGreen
|
|||
|
arguments : 1 (rgba)
|
|||
|
retourne la meme valeur du vert
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getBlue
|
|||
|
arguments : 1 (rgba)
|
|||
|
retourne la meme valeur du bleu
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getAlpha
|
|||
|
arguments : 1 (rgba)
|
|||
|
retourne la meme valeur de l alpha
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
makeRGB
|
|||
|
arguments : 3 ou 4 (int)
|
|||
|
retourne un rgb ou rgba
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
min
|
|||
|
arguments : n>0 (int ou double)
|
|||
|
retourne la valeur minimum de tous les arguments
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
max
|
|||
|
arguments : n>0 (int ou double)
|
|||
|
retourne la valeur maximum de tous les arguments
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
depends
|
|||
|
arguments : aucun
|
|||
|
retourne zero
|
|||
|
sert uniquement a creer des dependances sur des elements de database pour appeler des actions
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
identity
|
|||
|
arguments : n>0
|
|||
|
retourne le premier argument
|
|||
|
sert un peu comme depends mais en plus permet un setup direct d une target
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
band
|
|||
|
arguments : n>=0
|
|||
|
retourne AND bit <20> bit de tous les arguments. 0 si nargs==0.
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
bor
|
|||
|
arguments : n>=0
|
|||
|
retourne OR bit <20> bit de tous les arguments. 0 si nargs==0.
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
bxor
|
|||
|
arguments : n==2
|
|||
|
retourne XOR bit <20> bit des 2 arguments.
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
bnot
|
|||
|
arguments : n==1
|
|||
|
retourne NOT bit <20> bit de l'argument.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
// GAME EXPRESSIONS
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
isOpen
|
|||
|
TODO
|
|||
|
TODO
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getCompassText
|
|||
|
arguments : 1
|
|||
|
convertit l'argument de type float (angle radian) en text
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getPactText
|
|||
|
arguments : 1 entier
|
|||
|
convertit l'argument qui represente le numero du type de pacte en chaine de character
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getDateText
|
|||
|
arguments : 1 entier
|
|||
|
convertit un jour ryzom (entier) en date sous le fromat 06 / 02 /03
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getDifficultyText
|
|||
|
arguments : 1 entier
|
|||
|
retourne en ucstring le texte de difficulte internationalise
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
isCharSelSlotEmpty
|
|||
|
arguments : 1 entier
|
|||
|
retourne un booleen qui dit si le arg1_ieme (0-5) slot de character summary est vide ou non
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getClientActionTypeText
|
|||
|
TODO
|
|||
|
TODO
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getClientActionTypeColor
|
|||
|
TODO
|
|||
|
TODO
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
is2HandItem
|
|||
|
arguments : 1
|
|||
|
true si le sheetId d<>finit un item <20> 2 mains
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSmoothServerTick
|
|||
|
arguments : 1
|
|||
|
convert a serverTick in smoothServerTick
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getVSIndex
|
|||
|
arguments : 2 strings (exemple : getVSIndex('fy_cheveux_shave01.sitem','HEAD'))
|
|||
|
retourne (int) l index de visual slot en fonction d un nom d item et d un type de slot
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getRoleId
|
|||
|
arguments : 1 string
|
|||
|
retourne un entier qui est le numero de la carriere (dans l enum)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getLightLevel
|
|||
|
arguments : 0
|
|||
|
donne le facteur de blend jour/nuit (un double de 0.0 a 1.0)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
strToIntFlag
|
|||
|
arguments : 1 string (exemple : strToIntFlag('Combat'))
|
|||
|
retourne (int) le numero du flag correspondant a la string
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSheathSlot
|
|||
|
arguments : 1 string (exemple : getSheathSlot('ammo1'))
|
|||
|
retourne (int) le numero du fourreau en fonction de son nom
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getInventorySlot
|
|||
|
arguments : 1 string (exemple : getInventorySlot('pack_animal1'))
|
|||
|
retourne (int) le numero du slot d inventaire en fonction de son nom
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getEquipmentSlot
|
|||
|
arguments : 1 string (exemple : getEquipmentSlot('FingerL'))
|
|||
|
retourne (int) le numero du slot d equipement en fonction de son nom
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getChatWin
|
|||
|
TODO
|
|||
|
TODO
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
// USER EXPRESSIONS
|
|||
|
// ***************************************************************************
|
|||
|
// ***************************************************************************
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSelectedItemPrice
|
|||
|
arguments : 0
|
|||
|
Get the price of the current selected item (should come from bot inventory)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getDraggedSheet
|
|||
|
arguments : 0
|
|||
|
Get ptr object on the current dragged sheet
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSelectedSheet
|
|||
|
arguments : 0
|
|||
|
Get ptr object on the current selected sheet
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getMenuItemSheet
|
|||
|
arguments : 0
|
|||
|
Get ptr object on the last sheet that trigerred menu.
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSheetID
|
|||
|
From a pointer on a sheet, get its sheetID
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSheetSelectionGroup
|
|||
|
From a pointer on a sheet, get its selection group name
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSheetName
|
|||
|
From a pointer on a sheet, or a sheet ID, get its name
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSheetIndex
|
|||
|
From a pointer on a sheet, get its index in the parent sheet list
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSheetQuantity
|
|||
|
From a pointer on a sheet, retrieve its quantity
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSheetQuality
|
|||
|
From a pointer on a sheet, retrieve its quality
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
isStackable
|
|||
|
From a pointer on a sheet, get its index in the parent sheet list
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
isTeleport
|
|||
|
From a pointer on a sheet or a sheet ID, test if an item is a teleport item
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
isPlainItem
|
|||
|
From a pointer on a sheet or a sheet ID, test if an item is a plain item (not a teleport, not a brick, not a pact)
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
isBrick
|
|||
|
From a sheet ID, test if an item is a brick
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
isPact
|
|||
|
From a sheet ID, test if an item is a pact
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
isRangeWeapon
|
|||
|
From a pointer on a sheet or a sheet ID, test if an item is a ran,ged weapon
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
isRoomLeftFor
|
|||
|
From a sheet ID, test if there's room for it in the inventory
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSelectionGroupNameFromId
|
|||
|
Get the name of a selection group from its id
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSelectionGroupIdFromName
|
|||
|
Get the id of a selection group from its name
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getItemsWeight(basePath, firstItem, numItem)
|
|||
|
Get the sum of all item's weight at the given db path
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getItemBranchsWeight(baseBranch, firstBranch, numBranch)
|
|||
|
Get the sum of all items located in several branchs
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSeedsWeight()
|
|||
|
Returns the weight of the seeds owned by the player
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getArmoursWeight()
|
|||
|
Returns the weight of all armours pieces worn by the player
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getInventoryWeight()
|
|||
|
Returns the weight of the whole inventory, not including beasts'inventory of course
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getSheathWeight()
|
|||
|
Returns the weight of the sheaths
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
getBranchSheetCategory()
|
|||
|
return the types of items that are contained in a branch (with the enum CDBCtrlSheet::TSheetCategory
|
|||
|
|
|||
|
// ***************************************************************************
|
|||
|
copySheet
|
|||
|
param 0 = pointer on a sheet, param 1 = dbAdress.
|
|||
|
This copy characteristics of a sheet (quantity, quality, sheet id) at the given database adress
|
|||
|
|
|||
|
|
|||
|
|