Interface ITextParagraph
περιεχόμενα
[
κρύβω
]ITextParagraph interface
Η διεπαφή για εργασία με την παράγραφο
public interface ITextParagraph
Ιδιότητες
Ονομα | Περιγραφή |
---|---|
AutoHyphenate { get; set; } | Λαμβάνει ή ορίζει μια τιμή που υποδεικνύει εάν [αυτόματος παύλα]. |
AutoLeading { get; set; } | Λαμβάνει ή ορίζει την αυτόματη προαγωγή. |
Burasagari { get; set; } | Λαμβάνει ή ορίζει μια τιμή που υποδεικνύει εάν αυτόITextParagraph είναι μπουρασαγίρι. |
ConsecutiveHyphens { get; set; } | Παίρνει ή ορίζει τις διαδοχικές παύλες. |
EndIndent { get; set; } | Λαμβάνει ή ορίζει την εσοχή τέλους. |
EveryLineComposer { get; set; } | Λαμβάνει ή ορίζει μια τιμή που υποδεικνύει εάν [κάθε συνθέτης γραμμής]. |
FirstLineIndent { get; set; } | Λαμβάνει ή ορίζει την εσοχή της πρώτης γραμμής. |
GlyphSpacing { get; set; } | Λαμβάνει ή ρυθμίζει την απόσταση των γλυφών. |
Hanging { get; set; } | Λαμβάνει ή ορίζει μια τιμή που υποδεικνύει εάν αυτόITextParagraph κρέμεται. |
HyphenatedWordSize { get; set; } | Λαμβάνει ή ορίζει το μέγεθος της λέξης με παύλα. |
Justification { get; set; } | Λαμβάνει ή ορίζει την αιτιολόγηση. |
KinsokuOrder { get; set; } | Λαμβάνει ή ορίζει τη σειρά kinsoku. |
LeadingType { get; set; } | Λαμβάνει ή ορίζει τον τύπο του οδηγού. |
LetterSpacing { get; set; } | Λαμβάνει ή ορίζει την απόσταση των γραμμάτων. |
PostHyphen { get; set; } | Παίρνει ή ορίζει την παύλα ανάρτησης. |
PreHyphen { get; set; } | Παίρνει ή ορίζει την προενωτική. |
SpaceAfter { get; set; } | Παίρνει ή ρυθμίζει το διάστημα μετά. |
SpaceBefore { get; set; } | Παίρνει ή ρυθμίζει το διάστημα πριν. |
StartIndent { get; set; } | Λαμβάνει ή ορίζει την εσοχή έναρξης. |
WordSpacing { get; set; } | Λαμβάνει ή ορίζει την απόσταση των λέξεων. |
Zone { get; set; } | Λαμβάνει ή ορίζει τη ζώνη. |
Μέθοδοι
Ονομα | Περιγραφή |
---|---|
Apply(ITextParagraph) | Εφαρμόζει την καθορισμένη παράγραφο. |
IsEqual(ITextParagraph) | Καθορίζει εάν η καθορισμένη παράγραφος είναι ίση. |
Παραδείγματα
Το ακόλουθο παράδειγμα δείχνει ότι η στοίχιση κειμένου μέσω του ITextPortion για γλώσσες από δεξιά προς τα αριστερά λειτουργεί σωστά.
[C#]
string sourceFilePath = "bidi.psd";
string exportFilePath = "bidiOutput.psd";
using (PsdImage image = (PsdImage)Image.Load(sourceFilePath))
{
TextLayer layer = (TextLayer)image.Layers[2];
ITextPortion[] portions = layer.TextData.Items;
portions[0].Paragraph.Justification = JustificationMode.Center;
layer.TextData.UpdateLayerData();
image.Save(exportFilePath);
}
Το ακόλουθο παράδειγμα κώδικα δείχνει τα τμήματα κειμένου επεξεργασίας και το στυλ κειμένου τους.
[C#]
const double Tolerance = 0.0001;
var filePath = "ThreeColorsParagraphs.psd";
var outputPath = "ThreeColorsParagraph_out.psd";
using (var im = (PsdImage)Image.Load(filePath))
{
for (int i = 0; i < im.Layers.Length; i++)
{
var layer = im.Layers[i] as TextLayer;
if (layer != null)
{
var portions = layer.TextData.Items;
if (portions.Length != 4)
{
throw new Exception();
}
// Έλεγχος κειμένου κάθε τμήματος
if (portions[0].Text != "Old " ||
portions[1].Text != "color" ||
portions[2].Text != " text\r" ||
portions[3].Text != "Second paragraph\r")
{
throw new Exception();
}
// Έλεγχος δεδομένων παραγράφων
// Οι παράγραφοι έχουν διαφορετική αιτιολόγηση
if (
(int)portions[0].Paragraph.Justification != 0 ||
(int)portions[1].Paragraph.Justification != 0 ||
(int)portions[2].Paragraph.Justification != 0 ||
(int)portions[3].Paragraph.Justification != 2)
{
throw new Exception();
}
// Όλες οι άλλες ιδιότητες της πρώτης και της δεύτερης παραγράφου είναι ίσες
for (int j = 0; j < portions.Length; j++)
{
var paragraph = portions[j].Paragraph;
if (Math.Abs(paragraph.AutoLeading - 1.2) > Tolerance ||
paragraph.AutoHyphenate != false ||
paragraph.Burasagari != false ||
paragraph.ConsecutiveHyphens != 8 ||
Math.Abs(paragraph.StartIndent) > Tolerance ||
Math.Abs(paragraph.EndIndent) > Tolerance ||
paragraph.EveryLineComposer != false ||
Math.Abs(paragraph.FirstLineIndent) > Tolerance ||
paragraph.GlyphSpacing.Length != 3 ||
Math.Abs(paragraph.GlyphSpacing[0] - 1) > Tolerance ||
Math.Abs(paragraph.GlyphSpacing[1] - 1) > Tolerance ||
Math.Abs(paragraph.GlyphSpacing[2] - 1) > Tolerance ||
paragraph.Hanging != false ||
paragraph.HyphenatedWordSize != 6 ||
paragraph.KinsokuOrder != 0 ||
paragraph.LetterSpacing.Length != 3 ||
Math.Abs(paragraph.LetterSpacing[0]) > Tolerance ||
Math.Abs(paragraph.LetterSpacing[1]) > Tolerance ||
Math.Abs(paragraph.LetterSpacing[2]) > Tolerance ||
paragraph.LeadingType != LeadingMode.Auto ||
paragraph.PreHyphen != 2 ||
paragraph.PostHyphen != 2 ||
Math.Abs(paragraph.SpaceBefore) > Tolerance ||
Math.Abs(paragraph.SpaceAfter) > Tolerance ||
paragraph.WordSpacing.Length != 3 ||
Math.Abs(paragraph.WordSpacing[0] - 0.8) > Tolerance ||
Math.Abs(paragraph.WordSpacing[1] - 1.0) > Tolerance ||
Math.Abs(paragraph.WordSpacing[2] - 1.33) > Tolerance ||
Math.Abs(paragraph.Zone - 36.0) > Tolerance)
{
throw new Exception();
}
}
// Έλεγχος δεδομένων στυλ
// Τα στυλ έχουν διαφορετικά χρώματα και μέγεθος γραμματοσειράς
if (Math.Abs(portions[0].Style.FontSize - 12) > Tolerance ||
Math.Abs(portions[1].Style.FontSize - 12) > Tolerance ||
Math.Abs(portions[2].Style.FontSize - 12) > Tolerance ||
Math.Abs(portions[3].Style.FontSize - 10) > Tolerance)
{
throw new Exception();
}
if (portions[0].Style.FillColor != Color.FromArgb(255, 145, 0, 0) ||
portions[1].Style.FillColor != Color.FromArgb(255, 201, 128, 2) ||
portions[2].Style.FillColor != Color.FromArgb(255, 18, 143, 4) ||
portions[3].Style.FillColor != Color.FromArgb(255, 145, 42, 100))
{
throw new Exception();
}
for (int j = 0; j < portions.Length; j++)
{
var style = portions[j].Style;
if (style.AutoLeading != true ||
style.HindiNumbers != false ||
style.Kerning != 0 ||
style.Leading != 0 ||
style.StrokeColor != Color.FromArgb(255, 175, 90, 163) ||
style.Tracking != 50)
{
throw new Exception();
}
}
// Παράδειγμα επεξεργασίας κειμένου
portions[0].Text = "Hello ";
portions[1].Text = "World";
// Παράδειγμα αφαίρεσης τμημάτων κειμένου
layer.TextData.RemovePortion(3);
layer.TextData.RemovePortion(2);
// Παράδειγμα προσθήκης νέου τμήματος κειμένου
var createdPortion = layer.TextData.ProducePortion();
createdPortion.Text = "!!!\r";
layer.TextData.AddPortion(createdPortion);
portions = layer.TextData.Items;
// Παράδειγμα επεξεργασίας παραγράφου και στυλ για τμήματα
// Ορισμός σωστής αιτιολόγησης
portions[0].Paragraph.Justification = JustificationMode.Right;
portions[1].Paragraph.Justification = JustificationMode.Right;
portions[2].Paragraph.Justification = JustificationMode.Right;
// Διαφορετικά χρώματα για κάθε στυλ. Θα αλλάξει, αλλά η απόδοση δεν υποστηρίζεται πλήρως
portions[0].Style.FillColor = Color.Aquamarine;
portions[1].Style.FillColor = Color.Violet;
portions[2].Style.FillColor = Color.LightBlue;
// Διαφορετική γραμματοσειρά. Θα αλλάξει, αλλά η απόδοση δεν υποστηρίζεται πλήρως
portions[0].Style.FontSize = 6;
portions[1].Style.FontSize = 8;
portions[2].Style.FontSize = 10;
layer.TextData.UpdateLayerData();
im.Save(outputPath, new PsdOptions(im));
break;
}
}
}
Δείτε επίσης
- χώρος ονομάτων Aspose.PSD.FileFormats.Psd.Layers.Text
- συνέλευση Aspose.PSD