• [导入]将图片资源文件整合到DLL文件中


    其实这样的想法早就有了,而且在FreeTextBox的后期版本里,使用了类似的方法,它是让所有的图片都成为一个独立的资源请求,就是说,所有的图片都由一个Header来处理,这样就让图片更加紧密的与应用程序融合在一起了。而它还只是用了Header来处理图片请求,而实际的图片还是在文件夹里。

    其实我们可以把图片当成资源文件加在DLL文件里。首先在项目里添加一个资源文件夹(Resource),然后在里面放一些文件(例如:“BK024.jpg“),并且在属性上选择“ebabme resource”这样,就可以把图片添加到DLL文件里了(当然你的项目是一个DLL库项目)。

    接下来就是取得这个图片的数据:设你的项目里有一个类”BasePage”,它的程序和集与上面的图片资源在同一个DLL文件里,那么我们可以这样来取得它的数据:

        string m_fullResource1 = "Webb.WAVE.Pages.Resource.BK024.jpg";
        byte[] m_fileContent1;
        Stream stream1 = typeof(BasePage).Assembly.GetManifestResourceStream(m_fullResource1);
        m_fileContent1 = new byte[stream1.Length];
        stream1.Read(m_fileContent1, 0, m_fileContent1.Length);

    这样,在m_fileContent1数组里就包含了所有的图片信息,下面只用把它输出到页面上或者存放到其它文件里都可。我只简单的把它输出在了页面上,
        string m_fullResource1 = "Webb.WAVE.Pages.Resource.BK024.jpg";
        //byte[] m_fileContent1;
        Stream stream1 = typeof(BasePage).Assembly.GetManifestResourceStream(m_fullResource1);
        //m_fileContent1 = new byte[stream1.Length];
        //stream1.Read(m_fileContent1, 0, m_fileContent1.Length);
        System.Drawing.Image m_image =  System.Drawing.Image.FromStream(stream1);    
        m_image.Save(Response.OutputStream,ImageFormat.Jpeg);
        stream1.Close();
        Response.End();

    运行结果:


    文章来源:http://computer.mblogger.cn/wucountry/posts/49808.aspx
    ================================
      /\_/\                        
     (=^o^=)  Wu.Country@侠缘      
     (~)@(~)  一辈子,用心做一件事!
    --------------------------------
      学而不思则罔,思而不学则怠!  
    ================================
  • 相关阅读:
    记录一次.Net框架Bug发现和提交过程:.Net Framework和.Net Core均受影响
    浅谈 Angular 项目实战
    Angular CLI 升级 6.0 之后遇到的问题
    构建具有用户身份认证的 Ionic 应用
    关于 Angular 跨域请求携带 Cookie 的问题
    使用 ng build 构建后资源地址引用错误的问题
    React 系列教程 1:实现 Animate.css 官网效果
    如何在已有的 Web 应用中使用 ReactJS
    关于浏览器后退操作与页面缓存问题
    三阶魔方公式速记
  • 原文地址:https://www.cnblogs.com/WuCountry/p/305628.html
Copyright © 2020-2023  润新知