多页的TIFF图片在aspx页面分页显示
一、逻辑实现:将数据库中的二进制TIFF图片读出并分页显示在页面上。
1.显示界面
public FrameDimension MyGuid;
public static int MyPos = ;
public static int totalPage = ;
public static MemoryStream stream;
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
string username = Request.QueryString["username"];
string sql = string.Format("select top(1) image from Image_Table where image_code=( select new_sjbh from new_ksy_dzpz where new_ksy_dzpzid='{0}' ) ", username);
DataTable dt = SqlHelper.GetTable(sql);
if (dt.Rows.Count > )
{
Image1.ImageUrl = "ShowImage.aspx?username=" + username + "&pagecount=0";
stream = new MemoryStream((byte[])dt.Rows[]["image"]);
// Bitmap bt = new Bitmap(Server.MapPath(Image1.ImageUrl));
Bitmap bt = new Bitmap(stream);
Guid gud = (Guid)bt.FrameDimensionsList.GetValue();
FrameDimension fds = new FrameDimension(gud);
totalPage = bt.GetFrameCount(fds);//获取页数
this.LabelPageCount.Text = totalPage.ToString();
this.LabelCurrentPage.Text = "";
if (totalPage == )
{
this.LinkButtonPreviousPage.Enabled = false;//上一页只读
this.LinkButtonFirstPage.Enabled = false;//首页只读
this.LinkButtonNextPage.Enabled = false;//下一页只读
this.LinkButtonLastPage.Enabled = false;//尾页只读
this.btnGo.Enabled = false; }
}
this.LinkButtonPreviousPage.Enabled = false;//上一页只读
this.LinkButtonFirstPage.Enabled = false;//首页只读
} }
//下载
protected void Button1_Click(object sender, EventArgs e)
{
string username = Request.QueryString["username"];
string sql = string.Format("select top(1) image,name from Image_Table where image_code=( select new_sjbh from new_ksy_dzpz where new_ksy_dzpzid='{0}' ) ", username);
DataTable dt = SqlHelper.GetTable(sql);
if (dt.Rows.Count > )
{
byte[] bytes = (byte[])dt.Rows[]["image"];
//下载单个凭证
Response.Buffer = true;
Page.Response.Clear();//清除缓冲区所有内容
Page.Response.ContentType = "application/octet-stream";
Page.Response.AddHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(dt.Rows[]["name"].ToString()) + ".tiff");
Response.BinaryWrite(bytes);
Response.Flush();
Response.End();
}
} //下一页
protected void LinkButtonNextPage_Click(object sender, EventArgs e)
{
int page = Convert.ToInt32(this.LabelCurrentPage.Text);
this.LabelCurrentPage.Text = Convert.ToString(page + );
fenyeshow(page);
} //上一页
protected void LinkButtonPreviousPage_Click(object sender, EventArgs e)
{
int page = Convert.ToInt32(this.LabelCurrentPage.Text) - ;
this.LabelCurrentPage.Text = Convert.ToString(page + );
fenyeshow(page);
}
//首页
protected void LinkButtonFirstPage_Click(object sender, EventArgs e)
{
int page = ;
this.LabelCurrentPage.Text = "";
fenyeshow(page);
}
//尾页
protected void LinkButtonLastPage_Click(object sender, EventArgs e)
{
int page = Convert.ToInt32(this.LabelPageCount.Text) - ;
this.LabelCurrentPage.Text = this.LabelPageCount.Text;
fenyeshow(page);
}
//Go
protected void btnGo_Click(object sender, EventArgs e)
{
int page = ;
if (this.txtNewPageIndex.Text != "")
{
int pagecount = Convert.ToInt32(this.LabelPageCount.Text);
int txt = Convert.ToInt32(this.txtNewPageIndex.Text);
if (txt <= pagecount && txt > )
{
page = Convert.ToInt32(this.txtNewPageIndex.Text) - ;
this.LabelCurrentPage.Text = this.txtNewPageIndex.Text;
}
}
if (page == )
{
this.LabelCurrentPage.Text = "";
}
fenyeshow(page);
}
//显示页面
public void fenyeshow(int pagecount)
{
string username = Request.QueryString["username"];
Image1.ImageUrl = "ShowImage.aspx?username=" + username + "&pagecount=" + pagecount.ToString();
if (this.LabelCurrentPage.Text == "")
{
this.LinkButtonPreviousPage.Enabled = false;//上一页只读
this.LinkButtonFirstPage.Enabled = false;//首页只读
this.LinkButtonNextPage.Enabled = true;
this.LinkButtonLastPage.Enabled = true;
}
if (this.LabelCurrentPage.Text == this.LabelPageCount.Text)
{
this.LinkButtonNextPage.Enabled = false;//下一页只读
this.LinkButtonLastPage.Enabled = false;//尾页只读
this.LinkButtonPreviousPage.Enabled = true;
this.LinkButtonFirstPage.Enabled = true;
}
}
Default.aspx
2.输出界面
public static MemoryStream stream;
protected void Page_Load(object sender, EventArgs e)
{
string username = Request.QueryString["username"];
int pagecount =int.Parse(Request.QueryString["pagecount"]); string sql = string.Format("select top(1) image from Image_Table where image_code=( select new_sjbh from new_ksy_dzpz where new_ksy_dzpzid='{0}' ) ", username);
DataTable dt = SqlHelper.GetTable(sql);
if (dt.Rows.Count>)
{
stream = new MemoryStream((byte[])dt.Rows[]["image"]);
}
if (pagecount >= )
{
getImage(pagecount.ToString());
} } void getImage(string pp)//根据路径输出Jpeg格式图片流
{
Bitmap bt = new Bitmap(stream);
Guid gud = (Guid)bt.FrameDimensionsList.GetValue();
FrameDimension fds = new FrameDimension(gud); if (pp != "")
{ int qq = Convert.ToInt16(pp);
bt.SelectActiveFrame(fds, qq);
} MemoryStream ss = new MemoryStream();
bt.Save(Server.MapPath("1.jpg"));
bt.Save(ss, ImageFormat.Jpeg);
byte[] bb = ss.GetBuffer();
ss.Read(bb, , (int)ss.Length);
//this.ID_img.ImageUrl =Convert.ToString(bb);
Response.BinaryWrite(bb);
ss.Close();
bt.Dispose();
Response.End();
}
ShowImage.aspx
Tips:会在根目录下生成1.jpg文件,若迁移代码 需删掉1.jpg文件!
多页的TIFF图片在aspx页面分页显示的更多相关文章
- js 将很长的内容进行页面分页显示
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- Winform 图片预览列表+分页显示
针对图片列表展示信息,一开始没有做过相关类似的功能,大多都是以表格行显示为主,所以刚开始实现这个功能的时候是懵逼的.无从下口.在网上搜索一时半会也没找到合适的解决方案.大致就是类似于下图这样,每条数据 ...
- JSP页面分页显示数据
效果如上图所示!最多显示10条:完整jsp和后台代码如下: <%@ page contentType="text/html;charset=UTF-8" %> < ...
- aspx页面图片用作html中img的url
背景:如果无法直接访问保存图片的服务器,我们可以先制作一个aspx页面用来接受服务器发送过来的图片,然后html页面请求aspx页面.对图片服务器起一定的缓冲保护作用,预防对黑客攻击造成危害. 注意: ...
- HTML控件ID和NAME属性的区别,以及如何在asp.net页面的.CS文件中获得.ASPX页面中HTML控件的值
在html中:name指的是用户名称,ID指的是用户注册是系统自动分配给用户的一个序列号. name是用来提交数据的,提供给表单用,可以重复: id则针对文档操作时候用,不能重复.如:document ...
- Aspx页面模拟WebService功能
在后台引入 using System.Web.Services 命名空间 然后在编写web服务方法: [WebMethod] public static string GetData(string t ...
- WebForm.aspx 页面通过 AJAX 访问WebForm.aspx.cs类中的方法,获取数据
WebForm.aspx 页面通过 AJAX 访问WebForm.aspx.cs类中的方法,获取数据 WebForm1.aspx 页面 (原生AJAX请求,写法一) <%@ Page Langu ...
- Jquery Ajax调用aspx页面方法
Jquery Ajax调用aspx页面方法 在asp.net webform开发中,用jQuery ajax传值一般有几种玩法 1)普通玩法:通过一般处理程序ashx进行处理: 2)高级玩法:通过as ...
- aspx页面中用Input 标签实现上传图片功能
实现上传图片功能需单独的建立一个aspx页面, 其中前台页面需要注意两点: a)实现上传功能的input的type="file" b)设置请求报文头为 enctype=" ...
随机推荐
- AutoMapper(二)
返回总目录 首先,先创建一个控制台项目,引用AutoMapper程序集,创建三个类User,UserDto,UserMappingProfile,下面的知识点的演示都以此项目为基础,代码分别如下: n ...
- 触控的手牌—Cocos Creator
科普 Cocos Creator是触控最新一代游戏工具链的名称.如果不太清楚的,可以先看一些新闻. 新编辑器Cocos Creator发布: 对不起我来晚了! http://ol.tgbus.co ...
- Android Studio快捷键switch case 轻松转换为if else
Android Studio快捷键switch case 轻松转换为if else 今天碰到的问题,没有找到资料,后面找到了方法,这个记下来,转载请注明出处:http://www.cnblogs.co ...
- Lind.DDD.Plugins~插件模式的集成
回到目录 对于Lind.DDD这个敏捷框架来说,插件也是其中的一个亮点,所有被认为是插件(Plugins)的模块都会继承自IPlugins这个标示接口,它在程序启动时会找到所有插件,并通过autofa ...
- 4.2w起步的软件公司创业历程
调查说,中国民营企业的生命期平均是2.8年,如今我的企业已走过近四年,而这一年却是我的迷茫期,不知道何去何从,现在写下 来与大家一起分享一下,写得较为凌乱,大家将就着看一下吧:) 先交待一下自己,我来 ...
- JQuery 滚动条插件perfect-scrollbar
原文地址 https://github.com/noraesae/perfect-scrollbar perfect-scrollbar Tiny but perfect jQuery scrollb ...
- Python模拟登陆新浪微博
上篇介绍了新浪微博的登陆过程,这节使用Python编写一个模拟登陆的程序.讲解与程序如下: 1.主函数(WeiboMain.py): import urllib2 import cookielib i ...
- Python标准模块--multiprocessing
1 模块简介 multiprocessing模块在Python2.6中引入.最初的multiprocessing是由Jesse Noller和Richard Oudkerk在PEP 371中定义.就像 ...
- 如何在删除ibdata1和ib_logfile的情况下恢复MySQL数据库
昨天,有个朋友对公司内部使用的一个MySQL实例开启binlog,但是在启动的过程中失败了(他也没提,为何会失败),在启动失败后,他删除了ibdata1和ib_logfile,后来,能正常启动了,但所 ...
- 重磅来袭,使用CRL实现大数据分库分表方案
关于分库分表方案详细介绍 http://blog.csdn.net/bluishglc/article/details/7696085 这里就不作详细描述了 分库分表方案基本脱离不了这个结构,受制于实 ...