-
Notifications
You must be signed in to change notification settings - Fork 10
Creating Icons for Custom Nodes
Custom nodes, that are the part of package, support icons.
-
Get ID of custom node. Open node with Notepad. Find its ID. It will look something like ID="4cdf5500-fe21-402e-acb7-bb9fc1b5a64b"
-
Open Visual Studio. As a template, choose
Visual C#
>Class Library
. -
Create in your solution resx file, named
PackageImages.resx
. Right click in Solution Explorer, chooseAdd
>New Item...
. Scroll down toResources File
.
Note: Before adding the images to our resources file, we need to disable the "strong typing" in our Resource file, because it will change our resource images names if we leave it on, causing our efforts to fail without warning.
With your .resx file selected, go to the Properties panel and clear the "Custom Tool" field. Failing to clear the "Custom Tool" field will result in Visual Studio converting periods to underscores in your resource names. Please verify before Building that your resource names have periods separating class names rather than underscores.
- Add to recently created file your image. Change your image resource name to
Custom-node-ID.Small
while changing your image file name (Solution Explorer) toCustom-node-ID.Small.png
Note: that if you change your image file names in the Windows Explorer before importing into Visual Studio, you will not have to do this step as VS will take care of it.
- Change icon persistence to Embedded in .resx
- Open .csproj file. Use Notepad.
- Uncomment BeforeBuild part.
- Write next code:
<Target Name="BeforeBuild">
<GetReferenceAssemblyPaths TargetFrameworkMoniker=".NETFramework, Version=v2.0">
<Output TaskParameter="FullFrameworkReferenceAssemblyPaths" PropertyName="FrameworkAssembliesPath" />
</GetReferenceAssemblyPaths>
<GenerateResource UseSourcePath="true" Sources="$(ProjectDir)PackageImages.resx"
OutputResources="$(ProjectDir)PackageImages.resources"
References="$(FrameworkAssembliesPath)System.Drawing.dll" />
<AL TargetType="library" EmbedResources="$(ProjectDir)PackageImages.resources"
OutputAssembly="$(OutDir)Package.customization.dll" />
</Target>
-
Rebuild your project.
Package.customization.dll
will be in project's output folder. -
Add Package.customization.dll to your package.
You can add default icon, if you want to use 1 icon for all custom nodes. You have to make all steps, described above. But name of your icon should be DefaultCustomNode.Small
You can also add a large icon (used when tool-tip dialog pops up) by following all of the above steps but naming your images/resources with the following name: Custom-node-ID.Large
and Custom-node-ID.Large.png
Small image should be 32x32px while large image works best at 128x128px.
##Extracting a large number of node IDs If your package contains a large number of nodes you can use this script to automatically extract the IDs of all nodes in a given directory: https://raw.githubusercontent.com/CAAD-RWTH/ClockworkForDynamo/master/workflow_samples/0.7.x/ExtractNodeIDs/ExtractNodeIDs.dyn