HP Workstation zx2000 OpenGL 1.1 Reference for HP-UX 11.x - Page 382

Index, Component, Conversion

Page 382 highlights

R glReadPixels 382 If format is GL_RED, GL_GREEN, GL_BLUE, GL_ALPHA, GL_RGB, GL_RGBA, GL_LUMINANCE, or GL_LUMINANCE_ALPHA and type is not GL_FLOAT, each component is multiplied by the multiplier shown in the following table. If type is GL_FLOAT, then each component is passed as is (or converted to the client's single-precision floating-point format if it is different from the one used by the GL). Type Index Mask GL_UNSIGNED_BYTE 28 - 1 GL_BYTE 27 - 1 GL_BITMAP 1 GL_UNSIGNED_SHORT 216 - 1 GL_SHORT 215 - 1 GL_UNSIGNED_INT 232 - 1 GL_INT 231 - 1 GL_FLOAT none Component Conversion (28 - 1)c [(28 - 1)c - 1] / 2 1 (216- 1)c [(216 - 1)c - 1] / 2 (232 - 1)c [(232 - 1)c - 1] / 2 c Return values are placed in memory as follows. If format is GL_COLOR_INDEX, GL_STENCIL_INDEX, GL_DEPTH_COMPONENT, GL_RED, GL_GREEN, GL_BLUE, GL_ALPHA, or GL_LUMINANCE, a single value is returned and the data for the ith pixel in the jth row is placed in location j · width + i. GL_RGB returns three values, GL_RGBA returns four values, and GL_LUMINANCE_ALPHA returns two values for each pixel, with all values corresponding to a single pixel occupying contiguous space in pixels. Storage parameters set by glPixelStore, such as GL_PACK_LSB_FIRST and GL_PACK_SWAP_BYTES, affect the way that data is written into memory. See glPixelStore for a description. Notes Values for pixels that lie outside the window connected to the current GL context are undefined. If an error is generated, no change is made to the contents of pixels. Errors • GL_INVALID_ENUM is generated if format or type is not an accepted value. • GL_INVALID_VALUE is generated if either width or height is negative. • GL_INVALID_OPERATION is generated if format is GL_COLOR_INDEX and the color buffers store RGBA color components. • GL_INVALID_OPERATION is generated if format is GL_STENCIL_INDEX and there is no stencil buffer. • GL_INVALID_OPERATION is generated if format is GL_DEPTH_COMPONENT and there is no depth buffer. Chapter 16

  • 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
  • 217
  • 218
  • 219
  • 220
  • 221
  • 222
  • 223
  • 224
  • 225
  • 226
  • 227
  • 228
  • 229
  • 230
  • 231
  • 232
  • 233
  • 234
  • 235
  • 236
  • 237
  • 238
  • 239
  • 240
  • 241
  • 242
  • 243
  • 244
  • 245
  • 246
  • 247
  • 248
  • 249
  • 250
  • 251
  • 252
  • 253
  • 254
  • 255
  • 256
  • 257
  • 258
  • 259
  • 260
  • 261
  • 262
  • 263
  • 264
  • 265
  • 266
  • 267
  • 268
  • 269
  • 270
  • 271
  • 272
  • 273
  • 274
  • 275
  • 276
  • 277
  • 278
  • 279
  • 280
  • 281
  • 282
  • 283
  • 284
  • 285
  • 286
  • 287
  • 288
  • 289
  • 290
  • 291
  • 292
  • 293
  • 294
  • 295
  • 296
  • 297
  • 298
  • 299
  • 300
  • 301
  • 302
  • 303
  • 304
  • 305
  • 306
  • 307
  • 308
  • 309
  • 310
  • 311
  • 312
  • 313
  • 314
  • 315
  • 316
  • 317
  • 318
  • 319
  • 320
  • 321
  • 322
  • 323
  • 324
  • 325
  • 326
  • 327
  • 328
  • 329
  • 330
  • 331
  • 332
  • 333
  • 334
  • 335
  • 336
  • 337
  • 338
  • 339
  • 340
  • 341
  • 342
  • 343
  • 344
  • 345
  • 346
  • 347
  • 348
  • 349
  • 350
  • 351
  • 352
  • 353
  • 354
  • 355
  • 356
  • 357
  • 358
  • 359
  • 360
  • 361
  • 362
  • 363
  • 364
  • 365
  • 366
  • 367
  • 368
  • 369
  • 370
  • 371
  • 372
  • 373
  • 374
  • 375
  • 376
  • 377
  • 378
  • 379
  • 380
  • 381
  • 382
  • 383
  • 384
  • 385
  • 386
  • 387
  • 388
  • 389
  • 390
  • 391
  • 392
  • 393
  • 394
  • 395
  • 396
  • 397
  • 398
  • 399
  • 400
  • 401
  • 402
  • 403
  • 404
  • 405
  • 406
  • 407
  • 408
  • 409
  • 410
  • 411
  • 412
  • 413
  • 414
  • 415
  • 416
  • 417
  • 418
  • 419
  • 420
  • 421
  • 422
  • 423
  • 424
  • 425
  • 426
  • 427
  • 428
  • 429
  • 430
  • 431
  • 432
  • 433
  • 434
  • 435
  • 436
  • 437
  • 438
  • 439
  • 440
  • 441
  • 442
  • 443
  • 444
  • 445
  • 446
  • 447
  • 448
  • 449
  • 450
  • 451
  • 452
  • 453
  • 454
  • 455
  • 456
  • 457
  • 458
  • 459
  • 460
  • 461
  • 462
  • 463
  • 464
  • 465
  • 466
  • 467
  • 468
  • 469
  • 470
  • 471
  • 472
  • 473
  • 474
  • 475
  • 476
  • 477
  • 478
  • 479
  • 480
  • 481
  • 482
  • 483
  • 484
  • 485
  • 486

R
glReadPixels
Chapter 16
382
If format is GL_RED, GL_GREEN, GL_BLUE, GL_ALPHA, GL_RGB, GL_RGBA,
GL_LUMINANCE, or GL_LUMINANCE_ALPHA and type is not GL_FLOAT, each
component is multiplied by the multiplier shown in the following table. If type is
GL_FLOAT, then each component is passed as is (or converted to the client’s
single-precision floating-point format if it is different from the one used by the GL).
Return values are placed in memory as follows. If
format
is GL_COLOR_INDEX,
GL_STENCIL_INDEX, GL_DEPTH_COMPONENT, GL_RED, GL_GREEN, GL_BLUE,
GL_ALPHA, or GL_LUMINANCE, a single value is returned and the data for the
i
th
pixel in the
j
th row is placed in location j ·
width + i
. GL_RGB returns three values,
GL_RGBA returns four values, and GL_LUMINANCE_ALPHA returns two values for
each pixel, with all values corresponding to a single pixel occupying contiguous space in
pixels
. Storage parameters set by glPixelStore, such as GL_PACK_LSB_FIRST and
GL_PACK_SWAP_BYTES, affect the way that data is written into memory. See
glPixelStore for a description.
Notes
Values for pixels that lie outside the window connected to the current GL context are
undefined.
If an error is generated, no change is made to the contents of
pixels
.
Errors
GL_INVALID_ENUM is generated if
format
or
type
is not an accepted value.
GL_INVALID_VALUE is generated if either
width
or
height
is negative.
GL_INVALID_OPERATION is generated if
format
is GL_COLOR_INDEX and the
color buffers store RGBA color components.
GL_INVALID_OPERATION is generated if
format
is GL_STENCIL_INDEX and
there is no stencil buffer.
GL_INVALID_OPERATION is generated if
format
is GL_DEPTH_COMPONENT
and there is no depth buffer.
Type
Index
Mask
Component
Conversion
GL_UNSIGNED_BYTE
2
8
- 1
(2
8
- 1)c
GL_BYTE
2
7
- 1
[(2
8
- 1)c - 1] / 2
GL_BITMAP
1
1
GL_UNSIGNED_SHORT
2
16
- 1
(2
16
- 1)c
GL_SHORT
2
15
- 1
[(2
16
- 1)c - 1] / 2
GL_UNSIGNED_INT
2
32
- 1
(2
32
- 1)c
GL_INT
2
31
- 1
[(2
32
- 1)c - 1] / 2
GL_FLOAT
none
c