summaryrefslogtreecommitdiff
path: root/DevIL/bindings/powerbasic/imginfo.bas
blob: e91634ee578640afd520966eec2e2587b3686c45 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
'-----------------------------------------------------------------------------
' Get Image info using DevIL
' DevIL Sample program using Powerbasic.
'
' by Peter Scheutz, Scheutz & Clementsen Design
' Web: http://www.scheutz.dk
' e-mail: sourcecode@scheutz.dk
'
' Last modified: 06/22/2002
' Based on DevIL Ver. 1.6.1 PB incs
' Filename: imgview.bas
'
' Released under the GNU Lesser General Public License:
' http://www.gnu.org/copyleft/lesser.html
'
' For information on use and download of DevIL goto: http://openil.sourceforge.net/
' (Get docs and "End User Package")
'
' Report errors in the Powerbasic includes to e-mail above.
'
' For general help on Powerbasic and DevIL, try the forums at:
' http://www.powerbasic.com
'-----------------------------------------------------------------------------


#Register None
#Compile Exe "imginfo.exe"
Option Explicit


#Include "il.inc"
#Include "ilu.inc"
#Include "ilut.inc"


Function OpenIL_TypeString(ByVal il_const As Dword) As String

    Select Case il_const
        Case %IL_BYTE : Function = "IL_BYTE"
        Case %IL_UNSIGNED_BYTE : Function = "IL_UNSIGNED_BYTE"
        Case %IL_SHORT : Function = "IL_SHORT"
        Case %IL_UNSIGNED_SHORT : Function = "IL_UNSIGNED_SHORT"
        Case %IL_INT : Function = "IL_INT"
        Case %IL_UNSIGNED_INT : Function = "IL_UNSIGNED_INT"
        Case %IL_FLOAT : Function = "IL_FLOAT"
        Case %GL_DOUBLE : Function = "GL_DOUBLE"

        Case Else : Function = "Type not defined"


    End Select

End Function




Function OpenIL_FormatString(ByVal il_const  As Dword) As String

    Select Case il_const
        Case %IL_COLOUR_INDEX : Function = "IL_COLOUR_INDEX"
        Case %IL_COLOR_INDEX : Function = "IL_COLOR_INDEX"
        Case %IL_RGB : Function = "IL_RGB"
        Case %IL_RGBA : Function = "IL_RGBA"
        Case %IL_BGR : Function = "IL_BGR"
        Case %IL_BGRA : Function = "IL_BGRA"
        Case %IL_LUMINANCE : Function = "IL_LUMINANCE"

        Case Else : Function = "Format not defined"


    End Select

End Function



Function OpenIL_OriginString(ByVal il_const As Dword) As String

    ' Origin Definitions
    Select Case il_const
        Case %IL_ORIGIN_LOWER_LEFT : Function = "IL_ORIGIN_LOWER_LEFT"
        Case %IL_ORIGIN_UPPER_LEFT : Function = "IL_ORIGIN_UPPER_LEFT"

        Case Else : Function = "Origin type not defined"
    End Select

End Function



Function OpenIL_PalTypeString(ByVal il_const As Dword) As String

    ' Palette types
    Select Case il_const
        Case %IL_PAL_NONE : Function = "IL_PAL_NONE"
        Case %IL_PAL_RGB24 : Function = "IL_PAL_RGB24"
        Case %IL_PAL_RGB32 : Function = "IL_PAL_RGB32"
        Case %IL_PAL_RGBA32 : Function = "IL_PAL_RGBA32"
        Case %IL_PAL_BGR24 : Function = "IL_PAL_BGR24"
        Case %IL_PAL_BGR32 : Function = "IL_PAL_BGR32"
        Case %IL_PAL_BGRA32 : Function = "IL_PAL_BGRA32"

        Case Else : Function = "Pallete type not defined"
    End Select

End Function


Function PbMain() As Long

    Local ILErr As Dword
    Local info As  ILinfo
    Local ID As Dword
    Local errString As Asciiz*1024


    If  Len(Command$)=0 Then
        MsgBox "Usage: imginfo.exe filename"
        Exit Function
    End If

    ilInit

    ilGenImages ByVal 1, ID
    ILErr=ilGetError()
    If  ILErr <> 0 Then
            errString = iluErrorString(ILErr)
            MsgBox "Error in ilGenImages" & $CRLF &  errString
            Exit Function
    End If


    ilBindImage ID
    ILErr=ilGetError()
    If  ILErr <> 0 Then
            errString = iluErrorString(ILErr)
            MsgBox "Error in ilBindImage" & $CRLF &  errString
            GoTo done
    End If



   ' ilEnable %IL_FORMAT_SET
   ' ilEnable %IL_ORIGIN_SET
   ' ilEnable %IL_TYPE_SET
   '
   ' ilFormatFunc %IL_RGB
   ' ilOriginFunc %IL_ORIGIN_LOWER_LEFT
   ' ilTypeFunc %IL_UNSIGNED_BYTE
   '
   ' ilEnable %IL_CONV_PAL
   ' Do
   '     ILErr = ilGetError()
   ' Loop While (ILErr <> 0)





    ilLoadImage  Command$
    ILErr=ilGetError()
    If  ILErr <> 0 Then
            errString = iluErrorString(ILErr)
            MsgBox "Error in ilLoadImage" & $CRLF &  errString
            GoTo done
    End If


    iluGetImageInfo info
    ILErr=ilGetError()
    If  ILErr <> 0 Then
            errString = iluErrorString(ILErr)
            MsgBox "Error in iluGetImageInfo" & $CRLF &  errString
            GoTo done
    Else

        MsgBox "DevIL Image info: " & $CRLF & $CRLF & _
        "Id: " & $TAB & $TAB & Format$(info.iId) & $CRLF & _
        "Data Pointer"  & $TAB & Format$(info.iData) & $CRLF & _
        "Width: " & $TAB & $TAB & Format$(info.iWidth) & $CRLF & _
        "Height: " & $TAB & $TAB & Format$(info.iHeight) & $CRLF & _
        "Depth: " & $TAB & $TAB & Format$(info.iDepth) & $CRLF & _
        "Bpp: " & $TAB & $TAB & Format$(info.iBpp) & $CRLF & _
        "SizeOfData: " & $TAB & Format$(info.iSizeOfData) & $CRLF & _
        "Format: " & $TAB & $TAB & OpenIL_FormatString(info.iFormat) & $CRLF & _
        "Type: " & $TAB & $TAB & OpenIL_TypeString(info.iType) & $CRLF & _
        "Origin: " & $TAB & $TAB & OpenIL_OriginString(info.iOrigin) & $CRLF & _
        "PalType: " & $TAB & $TAB & OpenIL_PalTypeString(info.iPalType) & $CRLF & _
        "PalSize: " & $TAB & $TAB & Format$(info.iPalSize) & $CRLF & _
        "NumNext: "  & $TAB & Format$(info.iNumNext) & $CRLF & _
        "NumMips: " & $TAB & Format$(info.iNumMips) & $CRLF & _
        "NumLayers: "  & $TAB & Format$(info.iNumLayers)

    End If



done:
    ilDeleteImages 1 , ID

    ' clear additional errors
    Do
        ILErr = ilGetError()
    Loop While (ILErr <> 0)



End Function