BioLib 3.4.2

There is a newer version of this package available.
See the version list below for details.
dotnet add package BioLib --version 3.4.2                
NuGet\Install-Package BioLib -Version 3.4.2                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="BioLib" Version="3.4.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add BioLib --version 3.4.2                
#r "nuget: BioLib, 3.4.2"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install BioLib as a Cake Addin
#addin nuget:?package=BioLib&version=3.4.2

// Install BioLib as a Cake Tool
#tool nuget:?package=BioLib&version=3.4.2                

BioLib

Nuget DOI

A GUI-less version of Bio .NET library for editing & annotating various microscopy image formats. Supports all bioformats supported images. Integrates with ImageJ, running ImageJ filters & macro functions. Supports Windows, Linux and Mac. Check out the documentation.

Usage

//First call BioImage.Initialize to 
//initialize the Bioformats library.
BioImage.Initialize();

//Once initialized you can open OME, ImageJ tiff files, and Bio Tiff files with:
BioImage b = BioImage.OpenFile("file");

//Or if you want to use specifically the OME image reader you can use BioImage.OpenOME
BioImage b = BioImage.OpenOME("file");

//If you are working with a pyramidal image you can open a portion of a tiled image with OpenOME.
//BioImage.OpenOME(string file, int serie, bool tab, bool addToImages, bool tile, int tilex, int tiley, int tileSizeX, int tileSizeY)

//You can specify whether to open in a newtab as well as whether to add the image to 
//the Images.images table. As well as specify whether to open as a tile with the specified 
//tile X,Y position & tile width & height.    
BioImage.OpenOME("file",0,false,false,true,0,0,600,600);
//This will open a portion of the image as a tile and won't add it to the Images table.

//Once you have opened a tiled image with BioImage.OpenOME you can call the 
//GetTile(BioImage b, ZCT coord, int serie, int tilex, int tiley, int tileSizeX, int tileSizeY) method
// to quickly get another tile from different portion of the image. For BioGTK & BioLib
Bitmap bm = BioImage.GetTile(b, new ZCT(0,0,0), 0, 100, 100, 600, 600);

//To get the current coordinate of the ImageView you can call GetCoordinate.
ZCT cord = v.GetCoordinate();
//or to set the current coordinate
v.SetCoordinate(new ZCT(1,1,1));

//To create a point as well as any other ROI type you can call the ROI create methods.
ROI p = ROI.CreatePoint(cord, 0, 0);
ROI rect = ROI.CreateRectangle(cord, 0, 0, 100, 100);

//Usage of Graphics class for 16 & 48 bit images as well as regular bit depth images
//is very similar to System.Graphics.
//We create a new Graphics object by passing the Bitmap for BioGTK & BioLib and BufferInfo for BioCore
Graphics g = Graphics.FromImage(b.Buffers[0]);

//Then we create a pen by passing a ColorS which represent a Color with, 
//a higher bit depth (unsigned short) rather than a byte.
g.pen = new Pen(new ColorS(ushort.MaxValue, ushort.MaxValue, ushort.MaxValue));

//Then we can call the familiar methods DrawLine, DrawPolygon, FillPolygon etc.
g.DrawLine(0,0,100,100);
//Finally we dispose the Graphics object.
g.Dispose();

//We can also save the resulting image given the ID of the image in the Images table.
//All images opened with BioImage.OpenFile or BioImage.OpenOME are added to the 
//Images.images table with the filename as an ID.
BioImage.SaveFile("file","path");

//Usage of OMERO class.
OMERO.Connect("demo.openmicroscopy.org", 4064, "username", "password");
string[] files = OMERO.GetAllFiles().ToArray();
string[] dbs = OMERO.GetDatasets().ToArray();
string[] fs = OMERO.GetFolders().ToArray(); 
string[] dbf = OMERO.GetDatasetFiles("CZI").ToArray();

//Usage of QuPath class.
QuPath.Project qu = QuPath.OpenProject("test.qpproj");
BioImage[] bms = new BioImage[] { BioImage.OpenFile("test.ome.tif") };
List<BioImage[]> bims = new List<BioImage[]>();
bims.Add(bms);
QuPath.Project qp = QuPath.Project.FromImages(bims, "test.qpproj");
QuPath.Project.SaveProject("myproj.qpproj", bims);

//To convert between different pixel formats we can call for example To24Bit.
b.To24Bit();
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (3)

Showing the top 3 NuGet packages that depend on BioLib:

Package Downloads
BioCore

A .NET library & program for annotating, & editing various microscopy imaging formats using Bioformats supported images. including whole slide, pyramidal & series.

BioGTK

A .NET application & library for editing & annotating various microscopy image formats. Supports all bioformats supported images. Integrates with ImageJ, running ImageJ filters & macro functions. Supports Windows, Linux and Mac.

BioImager

A .NET microscopy imaging application based on Bio library. Supports various microscopes by using imported libraries & GUI automation. Supported libraries include Prior® & Zeiss® & all devices supported by Micromanager 2.0 and python-microscope.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
3.5.0 85 1/20/2025
3.4.2 41 1/8/2025
3.4.1 105 1/6/2025
3.4.0 101 1/5/2025
3.3.0 117 12/17/2024
3.2.0 100 12/10/2024
3.1.1 101 12/3/2024
3.1.0 90 12/2/2024
3.0.0 98 11/25/2024
2.9.2 90 11/19/2024
2.9.1.1 107 11/18/2024
2.9.1 94 11/17/2024
2.9.0.1 101 10/29/2024
2.9.0 92 10/29/2024
2.8.0 142 10/19/2024
2.7.3.2 107 10/10/2024
2.7.3.1 102 10/10/2024 2.7.3.1 is deprecated because it has critical bugs.
2.7.3 123 10/10/2024
2.7.2.1 110 10/1/2024
2.7.2 94 9/29/2024
2.7.1 110 9/28/2024
2.7.0.1 97 9/1/2024
2.7.0 103 8/29/2024
2.6.0 140 8/21/2024
2.5.0 111 7/26/2024
2.4.1 126 7/7/2024
2.4.0 106 5/2/2024
2.3.0 125 4/23/2024
2.2.1 154 2/17/2024
2.2.0 113 2/17/2024
2.1.0 152 2/10/2024
2.0.0 122 2/2/2024
1.9.0 175 12/24/2023
1.8.0 208 11/2/2023
1.7.0 447 9/1/2023
1.6.2 426 8/22/2023
1.6.1 402 8/19/2023
1.6.0 455 8/6/2023
1.5.2 475 8/2/2023
1.5.1 447 7/9/2023
1.5.0 429 7/8/2023
1.4.1 410 6/27/2023
1.4.0 377 5/15/2023
1.3.2 456 4/12/2023
1.3.1 496 4/1/2023
1.3.0 505 3/7/2023
1.2.1 556 3/4/2023
1.2.0 553 3/2/2023
1.1.1 509 3/2/2023
1.1.0 502 3/1/2023
1.0.0 252 3/1/2023

Fixed issue with channel indices.