如何在Silverlight图像控件上显示TIFF以Byte []形式

如何解决如何在Silverlight图像控件上显示TIFF以Byte []形式

|| 我创建了一个窗口服务,将所有TIFF文件放入数据库并将其存储为“ 0”。 现在,我希望能够通过Silverlight图像控件显示它们 所以我在绑定XAML期间使用Converter来将
Byte[]
转换为
Bitmap
,因为
Image.Source
仅接受eitheir URI(我没有在服务器上存储的文件,因此无法使用此方法)或
Bitmap
BitmapImage bmi = new BitmapImage();
if (value != null)
{
    ImageGallery imageGallery = value as ImageGallery;
    byte[] imageContent = imageGallery.ImageContent;
    string imageType = imageGallery.ImageType;
    using (MemoryStream ms = new MemoryStream(imageContent))
    {
        bmi.SetSource(ms);
    }
}
return bmi;
但是,由于Silverlight仅支持JPEG和PNG图像,因此在ѭ6处出现了异常。 因此,我进行了更多研究,并且知道我应该将TIFF的字节转换为JPEG或PNG的字节,然后它才能工作。 为此,我尝试了两种方法: 在服务器上进行转换:在我的RIA服务调用中,检索ѭ7之后,我遍历可用图像以将TIFF字节转换为JPEG字节。 但是它不起作用... 你能告诉我我做错了什么吗?
public IQueryable<ImageGallery> GetImageGalleries()
{
    var imageGalleries = this.ObjectContext.ImageGalleries.OrderBy(i=>i.ImageName);
    foreach (ImageGallery imageGallery in imageGalleries)
    {
        if (imageGallery.ImageType == \".tif\" || imageGallery.ImageType == \".tiff\")
        {
            //Convert the Tiff byte array format into JPEG stream format
            System.Drawing.Bitmap dImg = new System.Drawing.Bitmap(new MemoryStream(imageGallery.ImageContent));
            MemoryStream ms = new MemoryStream();
            dImg.Save(ms,System.Drawing.Imaging.ImageFormat.Jpeg);

            //then convert the JPEG stream format into JPEG byte array format
            byte[] buf = new byte[ms.Length];  
            ms.Read(buf,buf.Length);

            //Changing the format tiff byte[] of ImageGallery to jpeg byte[] 
            imageGallery.ImageContent = buf;
        }
    }
    return imageGalleries;
}
另一种解决方案是使用LibTiff.Net库在Silverlight上直接将TIFF的
Byte[]
直接转换为
WritableBitmap
。 但是,在深入研究其示例应用程序或使用Reflector查看源代码功能之后,我仍然不知道如何使用其库将TIFF的字节转换为
WritableBitmap
JPEG(或PNG),因为他们的示例仅显示了用于在文件目录中搜索TIFF的API。就我而言,服务器上没有现有文件。 有人可以帮我如何在Silverlight的图像控件上显示TIFF文件吗? 我搜索了论坛,但没有找到任何可靠的答案。 谢谢     

解决方法

我认为LibTiff将是必经之路。最终,
Tiff.ClientData
会接受作为tiff数据的
Stream
。如果您的tiff数据确实是
byte[]
,那么您只需在周围加上
MemoryStream
。 some 14更有可能从流中拉出,因此您可能甚至不需要此中介inter 14ѭ/
MemoryStream
。     ,参考LibTiff.net 添加此类:
using System;
using System.Collections.Generic;
using System.IO;
using System.Windows.Media.Imaging;
using BitMiracle.LibTiff.Classic;

namespace CoreTechs.X9
{
    public static class TiffUtility
    {
        public static Tiff CreateTiff(this byte[] bytes)
        {
            MemoryStream ms = new MemoryStream(bytes);
            Tiff tiff = Tiff.ClientOpen(\"in-memory\",\"r\",ms,new TiffStream());
            return tiff;
        }

        public static IEnumerable<WriteableBitmap> ConvertToWriteableBitmaps(this Tiff tiff)
        {
            if (tiff == null)
                throw new ArgumentNullException(\"tiff\",\"tiff is null.\");

            short dirs = tiff.NumberOfDirectories();

            for (int i = 0; i < dirs; i++)
            {
                if (tiff.SetDirectory((short)i))
                {
                    int tileCount = tiff.NumberOfTiles();
                    int stripCount = tiff.NumberOfStrips();

                    var frameWidthField = tiff.GetField(TiffTag.IMAGEWIDTH);
                    var frameHeightField = tiff.GetField(TiffTag.IMAGELENGTH);
                    var compressionField = tiff.GetField(TiffTag.COMPRESSION);
                    var xResolutionField = tiff.GetField(TiffTag.XRESOLUTION);
                    var yResolutionField = tiff.GetField(TiffTag.YRESOLUTION);
                    var samplesPerPixelField = tiff.GetField(TiffTag.SAMPLESPERPIXEL);

                    int frameWidth = frameWidthField != null && frameWidthField.Length > 0 ? frameWidthField[0].ToInt() : 0;
                    int frameHeight = frameHeightField != null && frameHeightField.Length > 0 ? frameHeightField[0].ToInt() : 0;
                    var compression = compressionField != null && compressionField.Length > 0 ? (Compression)compressionField[0].Value : Compression.NONE;
                    var xResolution = xResolutionField != null && xResolutionField.Length > 0 ? new double?(xResolutionField[0].ToDouble()) : null;
                    var yResolution = yResolutionField != null && yResolutionField.Length > 0 ? new double?(yResolutionField[0].ToDouble()) : null;
                    var samplesPerPixel = samplesPerPixelField != null && samplesPerPixelField.Length > 0 ? samplesPerPixelField[0].ToString() : String.Empty;

                    if (xResolution != null && yResolution == null)
                    {
                        yResolution = xResolution;
                    }

                    var buffer = new int[frameWidth * frameHeight];
                    tiff.ReadRGBAImage(frameWidth,frameHeight,buffer);

                    var bmp = new WriteableBitmap(frameWidth,frameHeight);
                    for (int y = 0; y < frameHeight; y++)
                    {
                        var ytif = y * frameWidth;
                        var ybmp = (frameHeight - y - 1) * frameWidth;

                        for (int x = 0; x < frameWidth; x++)
                        {
                            var currentValue = buffer[ytif + x];

                            // Shift the Tiff\'s RGBA format to the Silverlight WriteableBitmap\'s ARGB format
                            bmp.Pixels[ybmp + x] = Tiff.GetB(currentValue) | Tiff.GetG(currentValue) << 8 | Tiff.GetR(currentValue) << 16 | Tiff.GetA(currentValue) << 24;
                        }
                    }

                    yield return bmp;
                }
            }
        }
    }
}
使用如下扩展方法:
byte[] myHappyTiffData = GetMyTiffBytesFromSomewhere();
WriteableBitmap bmp = myHappyTiffData.CreateTiff().ConvertToWriteableBitmaps().FirstOrDefault();
myImageControl.Source = bmp;
    ,我们从LibTiff开始,作为我们媒体经理的解决方案。我不推荐。 如您所见,它为每个页面创建一个WriteableBitmap。 WB是您在Silverlight中可以使用的最妨碍性能的对象,因此,如果单页tiff数量超过1个,则您的应用程序将更快地耗尽内存,那么您可以说Avada Kedavra。 有些浏览器看上去可以加载大型的多页tiff文件,而不会杀死您的应用程序(以及浏览器和计算机),但需要支付可观的许可费,但目前我什么都没让您解码tiff并提取页面。 亚军: http://www.accusoft.com/ http://www.atalasoft.com/products/dotimage     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-