TagCloudGenerator 1.1.0
dotnet add package TagCloudGenerator --version 1.1.0
NuGet\Install-Package TagCloudGenerator -Version 1.1.0
<PackageReference Include="TagCloudGenerator" Version="1.1.0" />
paket add TagCloudGenerator --version 1.1.0
#r "nuget: TagCloudGenerator, 1.1.0"
// Install TagCloudGenerator as a Cake Addin #addin nuget:?package=TagCloudGenerator&version=1.1.0 // Install TagCloudGenerator as a Cake Tool #tool nuget:?package=TagCloudGenerator&version=1.1.0
TagCloudGenerator
<img src="https://www.nuget.org/Content/gallery/img/logo-header.svg?sanitize=true" height="30px">
TagCloudGenerator is a C# library that allows you to generate a tag cloud bitmap image from a given set of strings and their corresponding weights. You can customize the appearance of the tag cloud by specifying various options, such as font size, font color, background color, and more.
Download
TagCloudGenerator is available as Nuget Package now.
Sample Images
Below are some sample images showing the output of the TagCloudGenerator:
<table> <tr> <td><img width=1000 align="center" src="https://github.com/ZjzMisaka/AnimeReport/blob/main/tags.bmp"/></td> <td><img width=1000 align="center" src="https://github.com/ZjzMisaka/AnimeReport/blob/main/companies.bmp"/></td> </tr> </table>
Getting Started
You can use the TagCloudGenerator library by following these steps:
Create a dictionary of strings and their corresponding weights. The weights can be set to the number of occurrences of each string.
Dictionary<string, float> tagDic = new Dictionary<string, float>(); tagDic["J.C.STAFF"] = 32;
Create a
TagCloudOption
object, and set its properties as needed.TagCloudOption tagCloudOption = new TagCloudOption(); // Set tagCloudOption properties // tagCloudOption.Xxx = xxx;
If you want to specify special settings for individual characters, create a dictionary of
TagOption
objects.Dictionary<string, TagOption> tagOptionDic = new Dictionary<string, TagOption>(); // Set option for single text // tagOptionDic["J.C.STAFF"] = new TagOption() { Rotate = new Rotate(0) };
Create a
TagCloud
object using the dictionaries and theTagCloudOption
object, and then call theGet()
method to generate the bitmap image.Bitmap bmp = new TagCloud(tagDic, tagCloudOption, tagOptionDic).Get();
If you don't need to specify special settings for individual characters, you can omit the
tagOptionDic
parameter:Bitmap bmp = new TagCloud(tagDic, tagCloudOption).Get();
TagCloudOption Properties
The TagCloudOption
object allows you to customize various aspects of the tag cloud. Below is a list of its properties and their descriptions:
Property | Description |
---|---|
Range RandomRotateRange | If not null, take random values from RandomRotateRange |
List<int> RotateList | If RandomRotateRange is null, take rotate randomly from RotateList |
int TagSpacing | Minimum pixel spacing between adjacent tags |
int HorizontalOuterMargin | Minimum horizontal outer margin |
int VerticalOuterMargin | Minimum vertical outer margin |
List<Color> FontColorList | Set possible font colors for bitmap tags |
ColorOption BackgroundColor | Set background color for bitmap tags |
FontFamily FontFamily | Set font family for bitmap tags |
Range FontSizeRange | Set minimum and maximum font sizes |
double AngleStep | Set angle step for spiral algorithm |
double RadiusStep | Set radius step for spiral algorithm |
double AngleDecreaseFactor | Angle step decreasing factor |
double RadiusDecreaseFactor | Radius step decreasing factor |
bool IsRandomInitAngle | Set if is random init angle or not for spiral algorithm |
int HorizontalCanvasGrowthStep | Horizontal canvas growth step |
int VerticalCanvasGrowthStep | Vertical canvas growth step |
ImgSize OutputSize | Output bitmap image size |
ImgSize InitSize | Init bitmap image size, the canvas will grow when the canvas is filled |
string MaskPath | If you need to generate a tag cloud through masking, set the path for the masking image |
bool ShowMask | Set whether to display mask image in generated bitmap image |
bool StretchMask | Set whether to stretch the mask to match the canvas |
int Accuracy | Accuracy of TagSpacing check, default = 1, if =0 then check all pixel. It is used to increase operating efficiency |
TagOption Properties
The TagOption
object allows you to specify special settings for individual charactersin the tag cloud. Below is a list of its properties and their descriptions:
Property | Description |
---|---|
Rotate Rotate | Rotate of tag |
FontColor FontColor | FontColor of tag |
FontFamily FontFamily | FontFamily of tag |
License
This project is licensed under the OMSPL.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net6.0
- System.Drawing.Common (>= 7.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.