Instrukcja Dim
Deklaruje zmienną lub tablicę.
Jeśli zmienne są oddzielone przecinkami (np. DIM sPar1, sPar2, sPar3 AS STRING), zostaną zdefiniowane tylko zmienne typu Variant. Każdą zmienną należy definiować w osobnym wierszu.
Dim sPar1 As String
Dim sPar2 As String
Dim sPar3 As String
Funkcja Dim deklaruje zmienne lokalne wewnątrz podprogramów. Zmienne globalne są deklarowane za pomocą instrukcji PUBLIC lub PRIVATE.
Składnia:
[ReDim]Dim nazwa_zmiennej [(start To koniec)] [As typ_zmiennej][, nazwa_zmiennej2 [(start To koniec)] [As typ_zmiennej][,...]]
Parametry:
Nazwa_zmiennej: Nazwa dowolnej zmiennej lub tablicy.
Start, koniec: Wartości numeryczne lub stałe definiujące liczbę elementów (liczba_elementów = (koniec - start) + 1) i zakres indeksacji.
Jeśli na poziomie procedury zastosowano instrukcję ReDim, wartości startu i końca mogą być wyrażeniami numerycznymi.
Typ_zmiennej: Słowo kluczowe deklarujące typ danych zmiennej.
Słowo kluczowe: Typ zmiennej
Bool: Zmienna logiczna, która może przyjąć wartości True (prawda) lub False (fałsz)
Currency: Zmienna walutowa (zawierająca znak waluty i 4 miejsca dziesiętne)
Date: Zmienna daty
Double: Zmienna zmiennoprzecinkowa podwójnej precyzji (w zakresie od 1,79769313486232 x 10E308 do 4,94065645841247 x 10E-324)
Integer: Zmienna typu liczba całkowita (w zakresie od -32768 do 32767)
Long: Zmienna typu liczba całkowita długa (w zakresie od -2 147 483 648 do 2 147 483 647)
Object: Zmienna typu obiekt (uwaga: ta zmienna może być wcześniej zdefiniowana wyłącznie za pomocą instrukcji Set)
Single: Zmienna zmiennoprzecinkowa typu pojedyncza precyzja (w zakresie od 3,402823 x 10E38 do 1,401298 x 10E-45).
String: Zmienna w postaci ciągu znaków składająca się z maksymalnie 64 000 znaków ASCII.
[Variant]: Zmienna typu variant (zawiera wszystkie typy określone przez definicję). Jeśli słowo kluczowe nie zostało określone, zmienne są automatycznie definiowane jako typ Variant, chyba, że zostały użyte instrukcje od DefBool do DefVar.
W LibreOffice Basic nie ma obowiązku jawnego deklarowania zmiennych. Jednak każda tablica przed użyciem powinna zostać zadeklarowana. Zmienną można deklarować za pomocą instrukcji Dim. W przypadku deklaracji wielokrotnych zmienne należy rozdzielić przecinkami. Aby zadeklarować typ zmiennej, po jej nazwie należy podać znak deklaracji typu lub użyć odpowiedniego słowa kluczowego.
LibreOffice Basic obsługuje tablice jedno- lub wielowymiarowe zdefiniowane jako określony typ zmiennych. Tablice stosuje się w programach zawierających listy lub tabele, które należy edytować. Zaletą tablic jest możliwość adresowania pojedynczych elementów za pomocą indeksów, które mogą być wyrażeniami numerycznymi lub zmiennymi.
Tablice są deklarowane za pomocą instrukcji Dim. Istnieją dwa sposoby definiowania zakresu indeksu:
DIM text(20) as String REM 21 elementów numerowanych od 0 do 20
DIM text(5 to 25) as String REM 21 elementów numerowanych od 5 do 25
DIM text(-15 to 5) as String REM 21 elementów (w tym 0)
REM numerowane od -15 do 5
Dwuwymiarowe pole danych
DIM text(20,2) as String REM 63 elementy: od 0 do 20 na poziomie 1, od 0 do 20 na poziomie 2 i od 0 do 20 na poziomie 3.
Jeśli w podprogramie lub funkcji zadeklarowano tablicę o liczbie wymiarów zdefiniowanej za pomocą instrukcji ReDim, jej typ można zadeklarować jako dynamiczny. Z reguły wymiar tablicy można definiować raz i nie można go modyfikować. Wewnątrz podprogramu można jednak zadeklarować tablicę za pomocą instrukcji ReDim. Wymiary tablicy mogą być zdefiniowane wyłącznie w postaci wyrażeń numerycznych. Dzięki temu wielkość pól nie jest większa od wymaganej.
Przykład:
Sub ExampleDim1
Dim sVar As String
Dim iVar As Integer
sVar = "Office"
End Sub
Sub ExampleDim2
' Dwuwymiarowe pole danych
Dim stext(20,2) As String
Const sDim As String = " Wymiar:"
For i = 0 To 20
For ii = 0 To 2
stext(i,ii) = str(i) & sDim & str(ii)
Next ii
Next i
For i = 0 To 20
For ii = 0 To 2
MsgBox stext(i,ii)
Next ii
Next i
End Sub