glLineWidth

specify the width of rasterized lines

Signature

glLineWidth( GLfloat ( width ) )-> void
glLineWidth( )

Parameters

VariablesDescription
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 glEnable and glDisable with argument GL_LINE_SMOOTH . 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 $\mathit{x}>=\mathit{y}$ , 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 glGet with arguments GL_ALIASED_LINE_WIDTH_RANGE , GL_SMOOTH_LINE_WIDTH_RANGE , and GL_SMOOTH_LINE_WIDTH_GRANULARITY .

Notes

The line width specified by glLineWidth is always returned when GL_LINE_WIDTH 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 glGet with GL_ALIASED_LINE_WIDTH_RANGE to determine the maximum width.
In OpenGL 1.2, the tokens GL_LINE_WIDTH_RANGE and GL_LINE_WIDTH_GRANULARITY were replaced by GL_ALIASED_LINE_WIDTH_RANGE , GL_SMOOTH_LINE_WIDTH_RANGE , and GL_SMOOTH_LINE_WIDTH_GRANULARITY . The old names are retained for backward compatibility, but should not be used in new code.

Errors

GL_INVALID_VALUE is generated if width is less than or equal to 0.

Associated Gets

glGet with argument GL_LINE_WIDTH
glGet with argument GL_ALIASED_LINE_WIDTH_RANGE
glGet with argument GL_SMOOTH_LINE_WIDTH_RANGE
glGet with argument GL_SMOOTH_LINE_WIDTH_GRANULARITY
glIsEnabled with argument GL_LINE_SMOOTH

Sample Code References

The following code samples have been found which appear to reference the functions described here. Take care that the code may be old, broken or not even use PyOpenGL.

glLineWidth
OpenGLContext OpenGLContext/browser/vpcurve.py Lines: 75, 98
OpenGL-Demo PyOpenGL-Demo/redbook/lines.py Lines: 91, 98
{Artistic License} PymmLib applications/glutviewer.py Lines: 95, 218
{Artistic License} PymmLib mmLib/OpenGLDriver.py Lines: 285, 432, 480, 509, 559
{LGPL} VisionEgg VisionEgg/SphereMap.py Lines: 292, 299
{LGPL} VisionEgg VisionEgg/Text.py Lines: 331
{LGPL} PyMT examples/desktop/desktop-multi.py Lines: 5, 226
{LGPL} PyMT pymt/ui/widgets/speechbubble.py Lines: 11, 83
{LGPL} PyMT pymt/graphx/css.py Lines: 14, 113, 129
{LGPL} PyMT pymt/graphx/draw.py Lines: 160, 267, 419
{LGPL} Pyggel pyggel/misc.py Lines: 42
{LGPL} pygl2d pygl2d/draw.py Lines: 31, 48
{GPL} Scocca scocca/graphics/opengl/draw.py Lines: 25
Visvis utils/cropper.py Lines: 375, 429
Visvis core/line.py Lines: 683, 832
Visvis core/axises.py Lines: 788, 836, 2025
Visvis core/baseWibjects.py Lines: 93
Visvis examples/customWobject.py Lines: 43
Visvis functions/boxplot.py Lines: 228
Visvis functions/bar.py Lines: 148
Visvis wobjects/textures.py Lines: 748, 1185
Visvis wobjects/sliceTextures.py Lines: 246
Visvis wobjects/polygonalModeling.py Lines: 904
Visvis wibjects/sliders.py Lines: 409
Visvis wibjects/colorWibjects.py Lines: 534, 547, 698, 754