GlLineWidth

From QB64 Phoenix Edition Wiki
Revision as of 06:04, 1 May 2022 by SMcNeill (talk | contribs) (Created page with "'''_glLineWidth:''' specify the width of rasterized lines {{PageSyntax}} SUB _glLineWidth (BYVAL width AS SINGLE) void '''_glLineWidth'''(GLfloat {{Parameter|width}}); ; width : Specifies the width of rasterized lines. The initial value is 1. {{PageDescription}} '''_glLineWidth''' specifies the rasterized width of both aliased and antialiased lines. Using a line width other than 1 has different effects, depending on whether line antialiasing is enabled. To en...")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

_glLineWidth: specify the width of rasterized lines


Syntax

 SUB _glLineWidth (BYVAL width AS SINGLE)
 void _glLineWidth(GLfloat width);


width
Specifies the width of rasterized lines. The initial value is 1.


Description

_glLineWidth specifies the rasterized width of both aliased and antialiased lines. Using a line width other than 1 has different effects, depending on whether line antialiasing is enabled. To enable and disable line antialiasing, call Template:KW and Template:KW with argument Template:KW. Line antialiasing is initially disabled.

If line antialiasing is disabled, the actual width is determined by rounding the supplied width to the nearest integer. (If the rounding results in the value 0, it is as if the line width were 1.) If <math>|\Delta X| \ge |\Delta Y|</math>, i pixels are filled in each column that is rasterized, where i is the rounded value of width. Otherwise, i pixels are filled in each row that is rasterized.

If antialiasing is enabled, line rasterization produces a fragment for each pixel square that intersects the region lying within the rectangle having width equal to the current line width, length equal to the actual length of the line, and centered on the mathematical line segment. The coverage value for each fragment is the window coordinate area of the intersection of the rectangular region with the corresponding pixel square. This value is saved and used in the final rasterization step.

Not all widths can be supported when line antialiasing is enabled. If an unsupported width is requested, the nearest supported width is used. Only width 1 is guaranteed to be supported; others depend on the implementation. Likewise, there is a range for aliased line widths as well. To query the range of supported widths and the size difference between supported widths within the range, call Template:KW with arguments Template:KW, Template:KW, and Template:KW.


Template:PageNotes

The line width specified by _glLineWidth is always returned when Template:KW is queried. Clamping and rounding for aliased and antialiased lines have no effect on the specified value.

Nonantialiased line width may be clamped to an implementation-dependent maximum. Call Template:KW with Template:KW to determine the maximum width.

In OpenGL 1.2, the tokens Template:KW and Template:KW were replaced by Template:KW, Template:KW, and Template:KW. The old names are retained for backward compatibility, but should not be used in new code.


Template:PageErrors

Template:KW is generated if width is less than or equal to 0.


Template:PageUseWith

Template:KW with argument Template:KW

Template:KW with argument Template:KW

Template:KW with argument Template:KW

Template:KW with argument Template:KW

Template:KW with argument Template:KW


See also

SUB _GL Template:KW


Template:PageCopyright

Copyright 1991-2006 Silicon Graphics, Inc. This document is licensed under the SGI Free Software B License. For details, see http://oss.sgi.com/projects/FreeB/.