Package icyllis.arc3d.granite.geom
Class AnalyticArcStep
java.lang.Object
icyllis.arc3d.granite.GeometryStep
icyllis.arc3d.granite.geom.AnalyticArcStep
Analytic (SDF + HW derivatives) method to fill/stroke a butt/round/square stroked
arc curve, a circular sector, or a circular segment. The join type may be square or round,
for open arcs, and must be round for circular sector and circular segment.
The arc must be circular, not elliptical.
-
Nested Class Summary
Nested classes/interfaces inherited from class icyllis.arc3d.granite.GeometryStep
GeometryStep.ProgramImpl
-
Field Summary
Modifier and TypeFieldDescriptionstatic final VertexInputLayout.Attribute
Bitfield:
16-32 bits: painter's depth;
4-5 bits: join;
2-4 bits: dir;
join=0: round, join=1: miter;
dir=0: inside, dir=1: center, dir=2: outside;static final VertexInputLayout.AttributeSet
static final VertexInputLayout.AttributeSet
static final VertexInputLayout.Attribute
(center X, center Y, start angle, sweep angle)static final VertexInputLayout.Attribute
X is circle radius.
Y is stroke radius if stroked, or -1.0 if filled.
Z is local AA radius.static final VertexInputLayout.Attribute
W is half width for open arcs.Fields inherited from class icyllis.arc3d.granite.GeometryStep
DEPTH, FLAG_EMIT_COVERAGE, FLAG_EMIT_PRIMITIVE_COLOR, FLAG_HANDLE_SOLID_COLOR, FLAG_HAS_TEXTURES, FLAG_OUTSET_BOUNDS_FOR_AA, FLAG_PERFORM_SHADING, MODEL_VIEW, SOLID_COLOR
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
Appends a key on the KeyBuilder that reflects any variety in the code that the geometry processor subclass can emit.void
emitFragmentColorCode
(Formatter fs, String outputColor) Emits the fragment color code into the fragment shader.void
emitFragmentCoverageCode
(Formatter fs, String outputCoverage) Emits the fragment coverage code into the fragment shader.void
emitVaryings
(VaryingHandler varyingHandler, boolean usesFastSolidColor) void
emitVertexGeomCode
(Formatter vs, String worldPosVar, String localPosVar, boolean usesFastSolidColor) Emits the geometry code into the vertex shader.makeProgramImpl
(ShaderCaps caps) Returns a new instance of the appropriate implementation class for the given GeometryProcessor.void
writeMesh
(MeshDrawWriter writer, Draw draw, float[] solidColor, boolean mayRequireLocalCoords) Methods inherited from class icyllis.arc3d.granite.GeometryStep
appendAttributesToKey, depthStencilFlags, depthStencilSettings, emitSamplers, emitsCoverage, emitsPrimitiveColor, emitUniforms, getInputLayout, handlesSolidColor, hasInstanceAttributes, hasVertexAttributes, instanceAttributes, instanceBinding, instanceStride, makeColorAttribute, name, numInstanceAttributes, numInstanceLocations, numTextureSamplers, numVertexAttributes, numVertexLocations, performsShading, primitiveType, textureSamplerState, textureSamplerSwizzle, uniqueID, vertexAttributes, vertexBinding, vertexStride, writeUniformsAndTextures
-
Field Details
-
LOCAL_ARC
(center X, center Y, start angle, sweep angle) -
RADII
X is circle radius.
Y is stroke radius if stroked, or -1.0 if filled.
Z is local AA radius. -
RADII_ARC
W is half width for open arcs. -
FLAGS_AND_DEPTH
Bitfield:
16-32 bits: painter's depth;
4-5 bits: join;
2-4 bits: dir;
join=0: round, join=1: miter;
dir=0: inside, dir=1: center, dir=2: outside; -
INSTANCE_ATTRIBS
-
INSTANCE_ATTRIBS_FOR_ARC
-
-
Constructor Details
-
AnalyticArcStep
public AnalyticArcStep(int type)
-
-
Method Details
-
appendToKey
Description copied from class:GeometryStep
Appends a key on the KeyBuilder that reflects any variety in the code that the geometry processor subclass can emit.- Specified by:
appendToKey
in classGeometryStep
- See Also:
-
makeProgramImpl
Description copied from class:GeometryStep
Returns a new instance of the appropriate implementation class for the given GeometryProcessor. This method is called only when the specified key does not exist in the program cache.- Specified by:
makeProgramImpl
in classGeometryStep
- See Also:
-
emitVaryings
- Overrides:
emitVaryings
in classGeometryStep
-
emitVertexGeomCode
public void emitVertexGeomCode(Formatter vs, @Nonnull String worldPosVar, @Nullable String localPosVar, boolean usesFastSolidColor) Description copied from class:GeometryStep
Emits the geometry code into the vertex shader. Implementation must define "vec4 worldPosVar" with the given name and setup it. If localPosVar is not null, then it must write geometry's local pos to it.- Overrides:
emitVertexGeomCode
in classGeometryStep
-
emitFragmentColorCode
Description copied from class:GeometryStep
Emits the fragment color code into the fragment shader. This is either paint's solid color or per-vertex primitive color. SeeGeometryStep.FLAG_HANDLE_SOLID_COLOR
andGeometryStep.FLAG_EMIT_PRIMITIVE_COLOR
.- Overrides:
emitFragmentColorCode
in classGeometryStep
-
emitFragmentCoverageCode
Description copied from class:GeometryStep
Emits the fragment coverage code into the fragment shader.If
GeometryStep.emitsCoverage()
is false, this method is called for hard-edge coverage, discard the fragment if coverage is 0. Otherwise outputCoverage is non-null, and coverage will involve in blending operations.- Overrides:
emitFragmentCoverageCode
in classGeometryStep
-
writeMesh
public void writeMesh(MeshDrawWriter writer, Draw draw, @Nullable float[] solidColor, boolean mayRequireLocalCoords) - Overrides:
writeMesh
in classGeometryStep
-