StrokeColor
Contents
[
Hide
]Shape.StrokeColor property
Defines the color of a stroke.
public Color StrokeColor { get; set; }
Remarks
This is a shortcut to the Color
property.
The default value is Black.
Examples
Shows how to fill a shape with a solid color.
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
// Write some text, and then cover it with a floating shape.
builder.Font.Size = 32;
builder.Writeln("Hello world!");
Shape shape = builder.InsertShape(ShapeType.CloudCallout, RelativeHorizontalPosition.LeftMargin, 25,
RelativeVerticalPosition.TopMargin, 25, 250, 150, WrapType.None);
// Use the "StrokeColor" property to set the color of the outline of the shape.
shape.StrokeColor = Color.CadetBlue;
// Use the "FillColor" property to set the color of the inside area of the shape.
shape.FillColor = Color.LightBlue;
// The "Opacity" property determines how transparent the color is on a 0-1 scale,
// with 1 being fully opaque, and 0 being invisible.
// The shape fill by default is fully opaque, so we cannot see the text that this shape is on top of.
Assert.AreEqual(1.0d, shape.Fill.Opacity);
// Set the shape fill color's opacity to a lower value so that we can see the text underneath it.
shape.Fill.Opacity = 0.3;
doc.Save(ArtifactsDir + "Shape.Fill.docx");
Shows how to iterate over all the shapes in a document.
public void VisitShapes()
{
Document doc = new Document(MyDir + "Revision shape.docx");
ShapeAppearancePrinter visitor = new ShapeAppearancePrinter();
doc.Accept(visitor);
Console.WriteLine(visitor.GetText());
}
/// <summary>
/// Logs appearance-related information about visited shapes.
/// </summary>
private class ShapeAppearancePrinter : DocumentVisitor
{
public ShapeAppearancePrinter()
{
mShapesVisited = 0;
mTextIndentLevel = 0;
mStringBuilder = new StringBuilder();
}
/// <summary>
/// Appends a line to the StringBuilder with one prepended tab character for each indent level.
/// </summary>
private void AppendLine(string text)
{
for (int i = 0; i < mTextIndentLevel; i++) mStringBuilder.Append('\t');
mStringBuilder.AppendLine(text);
}
/// <summary>
/// Return all the text that the StringBuilder has accumulated.
/// </summary>
public string GetText()
{
return $"Shapes visited: {mShapesVisited}\n{mStringBuilder}";
}
/// <summary>
/// Called when this visitor visits the start of a Shape node.
/// </summary>
public override VisitorAction VisitShapeStart(Shape shape)
{
AppendLine($"Shape found: {shape.ShapeType}");
mTextIndentLevel++;
if (shape.HasChart)
AppendLine($"Has chart: {shape.Chart.Title.Text}");
AppendLine($"Extrusion enabled: {shape.ExtrusionEnabled}");
AppendLine($"Shadow enabled: {shape.ShadowEnabled}");
AppendLine($"StoryType: {shape.StoryType}");
if (shape.Stroked)
{
Assert.AreEqual(shape.Stroke.Color, shape.StrokeColor);
AppendLine($"Stroke colors: {shape.Stroke.Color}, {shape.Stroke.Color2}");
AppendLine($"Stroke weight: {shape.StrokeWeight}");
}
if (shape.Filled)
AppendLine($"Filled: {shape.FillColor}");
if (shape.OleFormat != null)
AppendLine($"Ole found of type: {shape.OleFormat.ProgId}");
if (shape.SignatureLine != null)
AppendLine($"Found signature line for: {shape.SignatureLine.Signer}, {shape.SignatureLine.SignerTitle}");
return VisitorAction.Continue;
}
/// <summary>
/// Called when this visitor visits the end of a Shape node.
/// </summary>
public override VisitorAction VisitShapeEnd(Shape shape)
{
mTextIndentLevel--;
mShapesVisited++;
AppendLine($"End of {shape.ShapeType}");
return VisitorAction.Continue;
}
/// <summary>
/// Called when this visitor visits the start of a GroupShape node.
/// </summary>
public override VisitorAction VisitGroupShapeStart(GroupShape groupShape)
{
AppendLine($"Shape group found: {groupShape.ShapeType}");
mTextIndentLevel++;
return VisitorAction.Continue;
}
/// <summary>
/// Called when this visitor visits the end of a GroupShape node.
/// </summary>
public override VisitorAction VisitGroupShapeEnd(GroupShape groupShape)
{
mTextIndentLevel--;
AppendLine($"End of {groupShape.ShapeType}");
return VisitorAction.Continue;
}
private int mShapesVisited;
private int mTextIndentLevel;
private readonly StringBuilder mStringBuilder;
}
See Also
- class Shape
- namespace Aspose.Words.Drawing
- assembly Aspose.Words