Skip to content

Commit

Permalink
Merge pull request #596 from SixLabors/af/beta4
Browse files Browse the repository at this point in the history
Update Shapes (.Text) and add tests for DrawText
  • Loading branch information
antonfirsov authored May 25, 2018
2 parents ae291c9 + 196d405 commit d65e152
Show file tree
Hide file tree
Showing 5 changed files with 116 additions and 42 deletions.
3 changes: 1 addition & 2 deletions src/ImageSharp.Drawing/ImageSharp.Drawing.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -38,9 +38,8 @@
</ItemGroup>
<ItemGroup>
<PackageReference Include="SixLabors.Core" Version="1.0.0-beta0005" />
<PackageReference Include="SixLabors.Shapes" Version="1.0.0-ci0018" />
<PackageReference Include="SixLabors.Shapes.Text" Version="1.0.0-beta0004" />
<AdditionalFiles Include="..\..\stylecop.json" />
<PackageReference Include="SixLabors.Shapes.Text" Version="1.0.0-beta0005" />
<PackageReference Include="StyleCop.Analyzers" Version="1.1.0-beta004">
<PrivateAssets>All</PrivateAssets>
</PackageReference>
Expand Down
114 changes: 114 additions & 0 deletions tests/ImageSharp.Tests/Drawing/Text/DrawTextOnImageTests.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,114 @@
// Copyright (c) Six Labors and contributors.
// Licensed under the Apache License, Version 2.0.

using System.Numerics;

using SixLabors.Fonts;
using SixLabors.ImageSharp.PixelFormats;
using SixLabors.ImageSharp.Processing;
using SixLabors.ImageSharp.Processing.Drawing;
using SixLabors.ImageSharp.Processing.Text;

using Xunit;
// ReSharper disable InconsistentNaming

namespace SixLabors.ImageSharp.Tests.Drawing.Text
{
using System;
using System.Linq;
using System.Text;

using SixLabors.Primitives;

[GroupOutput("Drawing/Text")]
public class DrawTextOnImageTests
{
private const string AB = "AB\nAB";

private const string TestText = "Sphinx of black quartz, judge my vow\n0123456789";

private const string TestText2 =
"THISISTESTWORDS ";

[Theory]
[WithSolidFilledImages(200, 100, "White", PixelTypes.Rgba32, 50, 0, 0, "SixLaborsSampleAB.woff", AB)]
[WithSolidFilledImages(900, 100, "White", PixelTypes.Rgba32, 50, 0, 0, "OpenSans-Regular.ttf", TestText)]
[WithSolidFilledImages(400, 40, "White", PixelTypes.Rgba32, 20, 0, 0, "OpenSans-Regular.ttf", TestText)]
[WithSolidFilledImages(1100, 200, "White", PixelTypes.Rgba32, 50, 150, 100, "OpenSans-Regular.ttf", TestText)]
public void FontShapesAreRenderedCorrectly<TPixel>(
TestImageProvider<TPixel> provider,
int fontSize,
int x,
int y,
string fontName,
string text)
where TPixel : struct, IPixel<TPixel>
{
Font font = CreateFont(fontName, fontSize);
string fnDisplayText = text.Replace("\n", "");
fnDisplayText = fnDisplayText.Substring(0, Math.Min(fnDisplayText.Length, 4));
TPixel color = NamedColors<TPixel>.Black;

provider.VerifyOperation(
img =>
{
img.Mutate(c => c.DrawText(text, new Font(font, fontSize), color, new PointF(x, y)));
},
$"{fontName}-{fontSize}-{fnDisplayText}-({x},{y})",
appendPixelTypeToFileName: false,
appendSourceFileOrDescription: true);
}

/// <summary>
/// Based on:
/// https://github.com/SixLabors/ImageSharp/issues/572
/// </summary>
[Theory]
[WithSolidFilledImages(2480, 3508, "White", PixelTypes.Rgba32)]
public void FontShapesAreRenderedCorrectly_LargeText<TPixel>(
TestImageProvider<TPixel> provider)
where TPixel : struct, IPixel<TPixel>
{
Font font = CreateFont("OpenSans-Regular.ttf", 36);

var sb = new StringBuilder();
string str = Repeat(" ", 78) + "THISISTESTWORDSTHISISTESTWORDSTHISISTESTWORDSTHISISTESTWORDSTHISISTESTWORDS";
sb.Append(str);

string newLines = Repeat(Environment.NewLine, 80);
sb.Append(newLines);

for (int i = 0; i < 10; i++)
{
sb.AppendLine(str);
}

var textOptions = new TextGraphicsOptions
{
Antialias = true,
ApplyKerning = true,
VerticalAlignment = VerticalAlignment.Top,
HorizontalAlignment = HorizontalAlignment.Left,
};
TPixel color = NamedColors<TPixel>.Black;

provider.VerifyOperation(
img =>
{
img.Mutate(c => c.DrawText(textOptions, sb.ToString(), font, color, new PointF(10, 5)));
},
false,
false);
}

private static string Repeat(string str, int times) => string.Concat(Enumerable.Repeat(str, times));

private static Font CreateFont(string fontName, int size)
{
var fontCollection = new FontCollection();
string fontPath = TestFontUtilities.GetPath(fontName);
Font font = fontCollection.Install(fontPath).CreateFont(size);
return font;
}
}
}
39 changes: 0 additions & 39 deletions tests/ImageSharp.Tests/Drawing/Text/OutputText.cs

This file was deleted.

Binary file not shown.

0 comments on commit d65e152

Please sign in to comment.