public int TiledThreshold { get; set; }
TiledThreshold # get and set (RasterMemoryThreshold)
An integer value that specifies the minimum amount of free memory required to allow the allocation of conventional images. Default value is 0.
If the amount of free memory falls below this threshold, all images will be allocated as tiled. The exception is when the image size is smaller than the tile size - in this case, the image will be allocated in conventional memory.
Values less than -100 are not allowed.
If the TiledThreshold value is < 0, it represents the required number of free bytes.
If the TiledThreshold value is 0, then there is no minimum requirement for free memory, all images are allocated as conventional if there is enough memory.
Tiled images use a combination of memory tiles and disk tiles. When an image is allocated, LEADTOOLS decides how many conventional memory tiles and how many disk tiles should be allocated. The TiledThreshold value influences the number of conventional tiles allocated as follows: the toolkit will not allocate any more conventional tiles when the amount of memory falls below TiledThreshold. When the amount of memory falls below TiledThreshold, disk tiles will be allocated and several swap buffers might back these disk tiles. For each image there will be at least one swap tile.
If the TiledThreshold value is > 0, then it represents a percentage of free memory out of the total memory. For example, when you pass -20, tiled images will be used when the amount of free physical and swap memory will drop below 20 percent of the total memory.
using Leadtools;
using Leadtools.Codecs;
public void RasterDefaultsExample()
{
// Set the limit for RasterImage object allocations
RasterMemoryThreshold threshold = RasterDefaults.MemoryThreshold;
threshold.MaximumGlobalRasterImageMemory = 20 * 1000 * 1024;
RasterDefaults.MemoryThreshold = threshold;
ShowValues();
// Create a raster image with current DPI
RasterImage image1 = new RasterImage(
RasterMemoryFlags.Conventional,
100,
100,
24,
RasterByteOrder.Bgr,
RasterViewPerspective.TopLeft,
null,
IntPtr.Zero,
0);
Console.WriteLine("Resolution of created image is {0} by {1} DPI", image1.XResolution, image1.YResolution);
// Change the resolution
int xOldResolution = RasterDefaults.XResolution;
int yOldResolution = RasterDefaults.YResolution;
int xNewResolution = 196;
int yNewResolution = 196;
RasterDefaults.XResolution = xNewResolution;
RasterDefaults.YResolution = yNewResolution;
ShowValues();
// Create another raster image
// Create a raster image with current DPI
RasterImage image2 = new RasterImage(
RasterMemoryFlags.Conventional,
100,
100,
24,
RasterByteOrder.Bgr,
RasterViewPerspective.TopLeft,
null,
IntPtr.Zero,
0);
Console.WriteLine("Resolution of created image is {0} by {1} DPI", image2.XResolution, image2.YResolution);
Debug.Assert(image2.XResolution == xNewResolution);
Debug.Assert(image2.YResolution == yNewResolution);
// Reset old values
RasterDefaults.XResolution = xOldResolution;
RasterDefaults.YResolution = yOldResolution;
image1.Dispose();
image2.Dispose();
}
void ShowValues()
{
Console.WriteLine("Current defaults:");
Console.WriteLine("MaximumThreadCount: {0}", RasterDefaults.MaximumThreadCount);
Console.WriteLine("XResolution: {0}", RasterDefaults.XResolution);
Console.WriteLine("YResolution: {0}", RasterDefaults.YResolution);
Console.WriteLine("DitheringMethod: {0}", RasterDefaults.DitheringMethod);
Console.WriteLine("MemoryFlags: {0}", RasterDefaults.MemoryFlags);
RasterMemoryThreshold threshold = RasterDefaults.MemoryThreshold;
Console.WriteLine("MemoryThreshold.TiledThreshold: {0}", threshold.TiledThreshold);
Console.WriteLine("MemoryThreshold.MaximumConventionalSize: {0}", threshold.MaximumConventionalSize);
Console.WriteLine("MemoryThreshold.TileSize: {0}", threshold.TileSize);
Console.WriteLine("MemoryThreshold.ConventionalTiles: {0}", threshold.ConventionalTiles);
Console.WriteLine("MemoryThreshold.ConventionalBuffers: {0}", threshold.ConventionalBuffers);
Console.WriteLine("MemoryThreshold.MaximumGlobalRasterImageMemory: {0}", threshold.MaximumGlobalRasterImageMemory);
Console.WriteLine("TemporaryDirectory: {0}", RasterDefaults.TemporaryDirectory);
}
Help Collections
Raster .NET | C API | C++ Class Library | HTML5 JavaScript
Document .NET | C API | C++ Class Library | HTML5 JavaScript
Medical .NET | C API | C++ Class Library | HTML5 JavaScript
Medical Web Viewer .NET
Multimedia
Direct Show .NET | C API | Filters
Media Foundation .NET | C API | Transforms
Supported Platforms
.NET, Java, Android, and iOS/macOS Assemblies
Imaging, Medical, and Document
C API/C++ Class Libraries
Imaging, Medical, and Document
HTML5 JavaScript Libraries
Imaging, Medical, and Document