GetBuildingBlock
Innehåll
[
Dölj
]GlossaryDocument.GetBuildingBlock method
Hittar ett byggblock med hjälp av det angivna galleriet, kategorin och namnet.
public BuildingBlock GetBuildingBlock(BuildingBlockGallery gallery, string category, string name)
Parameter | Typ | Beskrivning |
---|---|---|
gallery | BuildingBlockGallery | Galleriets kriterier. |
category | String | Kategorikriterierna. Kan varanull , i vilket fall den inte kommer att användas för jämförelse. |
name | String | Kriterierna för byggstensnamnet. |
Returvärde
Den matchande byggstenen ellernull
om ingen matchning hittades.
Anmärkningar
Detta är en bekvämlighetsmetod som itererar över alla byggblock i den här samlingen och returnerar det första byggblocket som matchar det angivna galleriet, den angivna kategorin och namnet.
Microsoft Word organiserar byggstenar i gallerier. gallerierna är fördefinierade med hjälp avBuildingBlockGallery
enum. Inom varje galleri kan byggblock organiseras i en eller flera kategorier. Kategorinamnet är en sträng. Varje byggblock har ett namn. Ett byggblocksnamn garanteras inte vara unikt.
Exempel
Visar sätt att komma åt byggstenar i ett ordlistadokument.
public void GlossaryDocument()
{
Document doc = new Document();
GlossaryDocument glossaryDoc = new GlossaryDocument();
BuildingBlock child1 = new BuildingBlock(glossaryDoc) { Name = "Block 1" };
glossaryDoc.AppendChild(child1);
BuildingBlock child2 = new BuildingBlock(glossaryDoc) { Name = "Block 2" };
glossaryDoc.AppendChild(child2);
BuildingBlock child3 = new BuildingBlock(glossaryDoc) { Name = "Block 3" };
glossaryDoc.AppendChild(child3);
BuildingBlock child4 = new BuildingBlock(glossaryDoc) { Name = "Block 4" };
glossaryDoc.AppendChild(child4);
BuildingBlock child5 = new BuildingBlock(glossaryDoc) { Name = "Block 5" };
glossaryDoc.AppendChild(child5);
Assert.AreEqual(5, glossaryDoc.BuildingBlocks.Count);
doc.GlossaryDocument = glossaryDoc;
// Det finns olika sätt att komma åt byggstenar.
// 1 - Hämta de första/sista byggstenarna i samlingen:
Assert.AreEqual("Block 1", glossaryDoc.FirstBuildingBlock.Name);
Assert.AreEqual("Block 5", glossaryDoc.LastBuildingBlock.Name);
// 2 - Hämta en byggsten via index:
Assert.AreEqual("Block 2", glossaryDoc.BuildingBlocks[1].Name);
Assert.AreEqual("Block 3", glossaryDoc.BuildingBlocks.ToArray()[2].Name);
// 3 - Hämta den första byggstenen som matchar ett galleri, namn och kategori:
Assert.AreEqual("Block 4",
glossaryDoc.GetBuildingBlock(BuildingBlockGallery.All, "(Empty Category)", "Block 4").Name);
// Vi gör det med hjälp av en anpassad besökare,
// vilket ger varje BuildingBlock i GlossaryDocument ett unikt GUID
GlossaryDocVisitor visitor = new GlossaryDocVisitor();
// Besök början/slutet av ordlistadokumentet.
glossaryDoc.Accept(visitor);
// Besök endast början av ordlistadokumentet.
glossaryDoc.AcceptStart(visitor);
// Besök endast slutet av ordlistadokumentet.
glossaryDoc.AcceptEnd(visitor);
Console.WriteLine(visitor.GetText());
// I Microsoft Word kan vi komma åt byggstenarna via "Insert" -> "Quick Parts" -> "Building Blocks Organizer".
doc.Save(ArtifactsDir + "BuildingBlocks.GlossaryDocument.dotx");
}
/// <summary>
/// Ger varje byggsten i ett besökt ordlistadokument ett unikt GUID.
/// Lagrar GUID-byggstensparen i en ordbok.
/// </summary>
public class GlossaryDocVisitor : DocumentVisitor
{
public GlossaryDocVisitor()
{
mBlocksByGuid = new Dictionary<Guid, BuildingBlock>();
mBuilder = new StringBuilder();
}
public string GetText()
{
return mBuilder.ToString();
}
public Dictionary<Guid, BuildingBlock> GetDictionary()
{
return mBlocksByGuid;
}
public override VisitorAction VisitGlossaryDocumentStart(GlossaryDocument glossary)
{
mBuilder.AppendLine("Glossary document found!");
return VisitorAction.Continue;
}
public override VisitorAction VisitGlossaryDocumentEnd(GlossaryDocument glossary)
{
mBuilder.AppendLine("Reached end of glossary!");
mBuilder.AppendLine("BuildingBlocks found: " + mBlocksByGuid.Count);
return VisitorAction.Continue;
}
public override VisitorAction VisitBuildingBlockStart(BuildingBlock block)
{
block.Guid = Guid.NewGuid();
mBlocksByGuid.Add(block.Guid, block);
return VisitorAction.Continue;
}
public override VisitorAction VisitBuildingBlockEnd(BuildingBlock block)
{
mBuilder.AppendLine("\tVisited block \"" + block.Name + "\"");
mBuilder.AppendLine("\t Type: " + block.Type);
mBuilder.AppendLine("\t Gallery: " + block.Gallery);
mBuilder.AppendLine("\t Behavior: " + block.Behavior);
mBuilder.AppendLine("\t Description: " + block.Description);
return VisitorAction.Continue;
}
private readonly Dictionary<Guid, BuildingBlock> mBlocksByGuid;
private readonly StringBuilder mBuilder;
}
Se även
- class BuildingBlock
- enum BuildingBlockGallery
- class GlossaryDocument
- namnutrymme Aspose.Words.BuildingBlocks
- hopsättning Aspose.Words