发明内容
本发明的目的在于提供病理切片的保存方法和装置,以降低病理切片的照片在显示的时候,对显示系统造成过重的负担。
第一方面,本发明实施例提供了病理切片的保存方法,包括:
建立图片容器;
按照每个图像碎片的行列值,将每个图像碎片放入图片容器中相应的位置,以填充图片容器;
将填充后的图片容器以图片流的形式保存到存储区。
结合第一方面,本发明实施例提供了第一方面的第一种可能的实施方式,其中,将填充后的图片容器以图片流的形式保存到存储区包括:
将填充后的图片容器以图片流的形式保存目标服务器上;
通过显示控件访问目标服务器,将图片流形式的图片容器保存在本地。
结合第一方面,本发明实施例提供了第一方面的第二种可能的实施方式,其中,将图片流形式的图片容器保存在本地包括:
将图片容器作为一个整体图片数据文件保存在本地。
结合第一方面,本发明实施例提供了第一方面的第三种可能的实施方式,其中,按照每个图像碎片的行列值,将每个图像碎片放入图片容器中相应的位置,以填充图片容器包括:
根据预先获取的像素宽、高计算每个图像碎片的行列值;
按照每个图像碎片的行列值,将层数相同的多个图像碎片放入同一个图片容器中。
结合第一方面,本发明实施例提供了第一方面的第四种可能的实施方式,其中,还包括:
通过运行显示控件,读取存储区的图片容器至系统缓存;
读取系统缓存内的图片容器进行显示。
结合第一方面,本发明实施例提供了第一方面的第五种可能的实施方式,其中,通过显示控件访问目标服务器,将图片流形式的图片容器保存在本地包括:
在获取到显示请求时,通过运行后台访问程序,从目标服务器中下载图片容器;
将下载得到的图片容器保存在本地。
结合第一方面,本发明实施例提供了第一方面的第六种可能的实施方式,其中,在获取到显示请求时,通过运行后台访问程序,从目标服务器中下载图片容器包括:
在获取到显示请求时,获取系统当前全部前台程序所占用的系统资源的占用量;
若占用量小于预设的阈值,则通过运行后台访问程序,从目标服务器中下载图片容器。
第二方面,本发明实施例还提供了病理切片的保存装置,其特征在于,包括:
建立模块,用于建立图片容器;
填充模块,用于按照每个图像碎片的行列值,将每个图像碎片放入图片容器中相应的位置,以填充图片容器;
保存模块,用于将填充后的图片容器以图片流的形式保存到存储区。
结合第二方面,本发明实施例提供了第二方面的第一种可能的实施方式,其中,保存模块包括:
第一保存单元,用于将填充后的图片容器以图片流的形式保存目标服务器上;
第二保存单元,用于通过显示控件访问目标服务器,将图片流形式的图片容器保存在本地。
结合第二方面,本发明实施例提供了第二方面的第二种可能的实施方式,其中,第二保存单元包括:
保存子单元,用于将图片容器作为一个整体图片数据文件保存在本地。
本发明实施例提供的病理切片的保存方法,采用图片流的保存方式,与现有技术中显示装置在将病理切片的图像碎片拼接到一起的时候,会导致显示装置的系统的负担过重相比,其通过预先采用图像流的拼接方式,将每个图像碎片放入到预先生成的图片容器中,在将图片容器填充满之后,将该图片容器以图片流的形式保存到的存储区,当显示装置需要显示图像切片的时候,只需要将存储区中的图片容器调取出即可,不再需要临时通过前台的显示控件对文件进行图片进行加载,降低了显示装置的负担。
为使本发明的上述目的、特征和优点能更明显易懂,下文特举较佳实施例,并配合所附附图,作详细说明如下。
具体实施方式
下面将结合本发明实施例中附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。通常在此处附图中描述和示出的本发明实施例的组件可以以各种不同的配置来布置和设计。因此,以下对在附图中提供的本发明的实施例的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施例。基于本发明的实施例,本领域技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。
将病理切片保存为电子图片(切片照片),便于医生随时随地的调取和观看,如在会诊时、会议时,均可以采用调取的方式将病理切片显示出来,来让多个专家同时观看。在保存病理切片的时候,一个病例切片不会只有一种保存方式(主要是指不会只保存一个分辨率的切片),这是考虑到医生在观察该病例切片的时候,需要将病理切片进行放大、移动等等操作,来保证医生能够从不同的层面来观察该病理切片,进而保证观察病例切片的准确性和完整性。而且,考虑到在同一台电脑(也可以是如投影器等其他显示器件)上同时加载完整的图像时,当分辨率很高的时候,电脑屏幕不会将完整的图像都显示出来,而且如果同时显示出来的话电脑的负荷会比较大。因此,在制作将病理切片制作为切片照片的时候,就会将切片照片进行分解,以形成多个图像碎片,形成如图2的形式,并且在显示的时候,只将一部分图像碎片拼接成一个局部的图像,在显示器上显示出来。可以想到的是,分辨率越高的切片照片,其图像碎片也就越多(通常,不论何种分辨率的切片照片,单个图像碎片的在显示器上呈现的大小均是相同的)。当用户进行放大的时候,电脑也就将分辨率更高的切片照片在显示器上显示出来。
随着照片的分辨率的提高,单个照片的数据量也就随之增大,在进行图像碎片拼接的时候,显示装置需要同时将这些照片放入其系统缓存中,这大大占用了系统的缓存。当同时需要显示的切片找的数量过多的时候,则会造成显示装置的系统的崩溃。
有鉴于此,本申请提供了病理切片的保存方法,如图1所示,包括:
S101,建立图片容器;
S102,按照每个图像碎片的行列值,将每个图像碎片放入图片容器中相应的位置,以填充图片容器;
S103,将填充后的图片容器以图片流的形式保存到存储区。
其中,步骤S101-步骤S103是在显示装置在将图片进行显示之前完成的,当然,步骤S101-步骤S103优选是在显示装置的系统后台执行的,在系统后台通过运行相应的程序来完成步骤S101-步骤S103,能够在不影响,或者是较小的影响前台程序的情况下进行。
具体的,系统后台的程序是指用户不会直接操作到的程序。后台程序可以是在显示装置内部运行的程序,也可以是由一台独立的具有计算功能的设备来执行的程序。通过显示装置在将显示前,将填充有图像碎片的图片容器保存到存储区,使得显示装置不再需要在显示的时候,临时将图像碎片进行拼接,从而降低了系统缓存的负担。
需要说明的是,图像碎片是将病理切片的切片照片分割后得到的。因此,为了说明图像碎片的位置,需要为每个图像碎片设置一个位置标号(图像碎片的行列值)。如图2所示,将图像碎片放入图片容器中的过程也就是将图像碎片按照其行列值放到指定的位置上,当一个图片容器填充满(图片容器中的每个位置上均填充有图片)了之后,便可以将该图片容器以图片流的方式保存到存储区中,进而显示装置通过读取存储区中的图片容器便可以直接显示切片照片了。
其中,步骤S103,将填充后的图片容器以图片流的形式保存到存储区包括如下两个步骤:
将填充后的图片容器以图片流的形式保存目标服务器上;
通过显示控件访问目标服务器,将图片流形式的图片容器保存在本地。
也就是,目标服务器是负责存储图片容器的,通过将图片容器以图片流的形式保存目标服务器上,使得使用者可以在不同的位置,以接入互联网的方式来读取到目标服务器中的图片容器。具体的,目标服务器的体现形式可以是网页,使用者通过该网页的地址链接,来访问服务器,进而从服务器中获取图片容器,并可以采用下载的方式将图片容器保存到本地。在需要使用的时候,用户可以通过读取保存在本地的图片容器来完成切片照片的显示。
为了减小显示装置的负担,步骤将图片流形式的图片容器保存在本地包括:
将图片容器作为一个整体图片数据文件保存在本地。
当图片容器作为一个整体图片数据文件进行保存的时候,可以将提高该图片容器读取的便捷性和快速性。
在将图像碎片填充到图片容器中之前,首先需要确定图像碎片的行列值,也就是步骤S102,按照每个图像碎片的行列值,将每个图像碎片放入图片容器中相应的位置,以填充图片容器包括:
根据预先获取的像素宽、高计算每个图像碎片的行列值;
按照每个图像碎片的行列值,将层数相同的多个图像碎片放入同一个图片容器中。
具体的,步骤S102可以具体分为如下几个步骤,如图3所示:
S301,根据切片照片的物理宽、高和参考点坐标,计算切片照片的中心坐标;
S302,根据预先获取的像素宽、高计算切片照片中指定图像碎片的行列数;
S303,根据行列数、当前切片照片的倍率,计算影响层数;
S304,若影响层数满足预设的条件,则通过比较当前调用的层数与影响层数,确定实际层数;
S305,根据参考点坐标、实际层数和中心坐标,计算指定图像碎片所对应的显示层数和显示横纵坐标;
S306,按照显示层数和显示横纵坐标将图像碎片填充到图片容器中。
更具体的,中心坐标分为两个部分,分别是中心点纵坐标和中心点横坐标,参考点坐标分为参考点纵坐标和参考点横坐标,其中,中心点横坐标=物理宽度值/2-参考点横坐标;中心点纵坐标=物理高度值/2-参考点纵坐标。
需要说明的是,如图4所示,示出了一个玻片上,所拍摄到组织的切片照片的示意图(俯视图)。该图中,组织是整个玻片中的一个局部,也就是拍摄出来的切片照片所呈现的区域,也只是玻片中的一个局部。物理宽和物理高分别指被拍摄的组织的实际宽度和高度(即,照片所对应的范围的高度和宽度)。中心坐标指的是该组织的中心点的坐标。参考点坐标一般指的是该组织左上角的坐标,当然,也可以统一为右上角,或者其他点位置。像素宽和像素高是受拍摄的相机所影响,在将该组织的切片照片拍摄完成之后,便会确定,像素宽、高为拍摄时通过机器分辨率系数转换所得。此系数单位为pixel/um,即像素和微米的比例值。此比例值为机器拍摄时自带的值。机器直接将参考点坐标(物理x、物理y)计算反馈得出,具体过程在此不过多说明。
进一步,本申请所提供的的病理切片的保存方法,还包括:
通过运行显示控件,读取存储区的图片容器至系统缓存;
读取系统缓存内的图片容器进行显示。
也就是,在需要显示的时候,用户可以调用显示控件,进而读取存储区中的图片容器到系统缓存,进而通过读取系统缓存中的图片容器进行显示。由于存储区中的图片容器中已经存储有图像碎片了,因此,系统缓存不再需要在显示前将图像碎片进行拼接,进而降低了系统缓存的占用度。
具体的,步骤,通过显示控件访问目标服务器,将图片流形式的图片容器保存在本地包括:
在获取到显示请求时,通过运行后台访问程序,从目标服务器中下载图片容器;
将下载得到的图片容器保存在本地。
也就是,显示装置在接收到用户的指令之后,是通过运行后台访问程序来下载图片容器的。一般情况下,后台程序是在不会过度影响前台程序的前提下进行操作的,因此,当用户向显示装置下达了下载指令的时候,显示装置通过系统后台来完成下载任务,能够保证系统前台运行的程序不会被过多的干扰。
更具体的,为了避免前台程序的运行受到干扰,显示装置在接收到用户所下达的指令之后,可以先获取系统资源的占用量,如果占用量过大的话,则暂停执行从目标服务器中下载图片容器的任务,如果占用量不大的话,则可以执行从目标服务器中下载图片容器的任务。
也就是,步骤在获取到显示请求时,通过运行后台访问程序,从目标服务器中下载图片容器包括:
在获取到显示请求时,获取系统当前全部前台程序所占用的系统资源的占用量;
若占用量小于预设的阈值,则通过运行后台访问程序,从目标服务器中下载图片容器。
其中,阈值可以是显示装置的CPU使用率,也可以是物理内存占用量。如果占用量大于预设的阈值,则显示装置会暂停执行下载的任务,但为了保证能够及时的从目标服务器中下载图片容器进行使用,还可以是:若占用量大于预设的阈值,实时监控前台程序所占用的系统资源的占用量,当前台程序所占用的系统资源的占用量小于预设的阈值时,则从目标服务器中下载图片容器。
下面以一个具体的实例来说明本申请所提供的病理切片的保存方法。
1,声明一个透明容器;
2,从倍率为20倍的切片照片中,获取最小层(用户指定的层数,也可以是其他层数)的宽高;
3,通过计算得出该最小层有r行c列,并将透明容器按照r行c列进行划分(具体为通过预设的算法,如使用像素宽高除以需要显示的倍率再除以瓦片流的边长来得出,行数=像素宽/需要显示的倍率/图片流形式的整体切片照片的边长,列数=像素高/需要显示的倍率/图片流形式的整体切片照片的边长);
4,通过循环行列数,来将每个图像碎片填充到r行c列的透明容器中,具体代码可以是如下的形式,
For(inti=0;i<r;i++)
{for(intj=0;j<c;j++)
{
将图片以坐标为i*256,j*256的坐标铺入容器内。
}};
5,将填充后的容器保存到网页上;
6,通过调用js控件访问该网页,获取图片,并以.jpg的形式进行保存,也可使用其他图片格式(png,bmp等)。
其中,步骤4,如果无法实现容器的底色为透明色,可以将容器的底色设置为白色。
本申请实施例还提供了与病理切片的保存方法向对应的病理切片的保存装置,该装置,包括:
建立模块,用于建立图片容器;
填充模块,用于按照每个图像碎片的行列值,将每个图像碎片放入图片容器中相应的位置,以填充图片容器;
保存模块,用于将填充后的图片容器以图片流的形式保存到存储区。
优选的,保存模块包括:
第一保存单元,用于将填充后的图片容器以图片流的形式保存目标服务器上;
第二保存单元,用于通过显示控件访问目标服务器,将图片流形式的图片容器保存在本地。
优选的,第二保存单元包括:
保存子单元,用于将图片容器作为一个整体图片数据文件保存在本地。
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的系统、装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
所述功能如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-OnlyMemory)、随机存取存储器(RAM,RandomAccessMemory)、磁碟或者光盘等各种可以存储程序代码的介质。
以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应所述以权利要求的保护范围为准。