cornerstoneTools 作用,用法,api使用心得
一、cornerstoneTools的用途
1、作用可以响应一些事件,例如鼠标按下的事件,鼠标滚轮的事件或按键或触摸事件
2、可以对视口进行缩放平移
3、可以在图像上绘制图形
4、可以在图像上绘制文本
二、外部依赖库
1、jquery
2、cornerstone
3、hammer
三、api
1、addToolState(element, toolType, data) element当前元素,toolType唯一标识,data元素总集,把所有元素绑定到tools工具中,element为当前挂载元素,主要功能影响切换下一张,不能切换下一张,下一张图片tools工具自然就不能对他操作,我的理解是这个api的意思是把所有元素都挂载tools工具。
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<link href="./css/bootstrap.min.css" rel="stylesheet">
<link href="./css/cornerstone.min.css" rel="stylesheet">
<style>
body{width: 100%;height: 100%;margin: 0;padding: 0;max-width: 750px;}
.container{position: absolute;width: 100%;height: 100%;left: 0;top: 0;}
</style>
</head>
<body>
<div class="container">
<div id="dicomImagebox">
<div class="dicomImage" id="dicomImage0" style="width:100%;height:100%;top:0px;left:0px; position:absolute">
</div>
</div>
</div>
</body>
<script src="./js/jquery.min.js"></script>
<!-- 引入 cornerstone 库 -->
<script src="./js/cornerstone.min.js"></script>
<script src="./js/dicomParser.min.js"></script>
<script src="../ImageLoader/cornerstoneWADOImageLoader.js"></script>
<script src="js/cornerstoneMath.min.js"></script>
<script src="js/hammer.js"></script>
<script src="js/cornerstoneTools.min.js"></script>
<script>
cornerstoneTools.external.Hammer = Hammer;
cornerstoneTools.external.cornerstone = cornerstone;
cornerstoneTools.external.cornerstoneMath = cornerstoneMath;
cornerstoneWADOImageLoader.external.cornerstoneMath = cornerstoneMath;
//指定要注册加载程序的基石实例
cornerstoneWADOImageLoader.external.cornerstone = cornerstone;
cornerstone.registerImageLoader("http", cornerstoneWADOImageLoader.loadImage);
cornerstone.registerImageLoader("https", cornerstoneWADOImageLoader.loadImage);
var config = {
webWorkerPath: "../ImageLoader/cornerstoneWADOImageLoaderWebWorker.js",
taskConfiguration: {
decodeTask: {
codecsPath: "../ImageLoader/cornerstoneWADOImageLoaderCodecs.js"
}
}
};
cornerstoneWADOImageLoader.webWorkerManager.initialize(config);
var baseUrl="";
var exampleStudyImageIds="";
var isInitLoad=true;
var isShow=true;
window.onload=function show(){
if (isShow === true) {
isShow = false;
var arr=["MR000000.dcm","MR000001.dcm"];
baseUrl = "http://localhost/testDICOM/CTStudy/";
exampleStudyImageIds = arr;
// 找到要渲染的元素
var canvas = document.getElementById("dicomImage0");
canvas.width=document.documentElement.clientWidth;
canvas.height=document.documentElement.clientHeight;
// 在 DOM 中将 canvas 元素注册到 cornerstone
cornerstone.enable(canvas);
// 拼接 url : cornerstoneWADOImageLoader 需要 wadouri 路径头
var imageUrl = baseUrl + exampleStudyImageIds[0];
var imageId = "wadouri:" + imageUrl; // Load & Display
cornerstone.loadAndCacheImage(imageId).then( function(image) { // 设置元素视口
var viewport = cornerstone.getDefaultViewportForImage(canvas, image);
// 显示图像
var datacorne=cornerstone.displayImage(canvas, image, viewport);
// 激活工具
initCanvasTools();
}
); }else{
isShow = true;
}
}
function initCanvasTools(){
var canvas = document.getElementById("dicomImage0");
console.log(canvas)
isInitLoad = false;
// 为 canvasStack 找到 imageIds
var allImageIds = [];
console.log(allImageIds)
$.each(exampleStudyImageIds,function(k,v) {
let imageUrl = "wadouri:" + baseUrl + v;
allImageIds.push(imageUrl);
});
console.log(allImageIds)
// Create canvasStack
var canvasStack = {
currentImageIdIndex: 0,
imageIds: allImageIds
};
// Enable Inputs
cornerstoneTools.mouseInput.enable(canvas);//鼠标按下事件
cornerstoneTools.mouseWheelInput.enable(canvas);//鼠标滚轮事件
cornerstoneTools.touchInput.enable(canvas);//手势事件
// Set the stack as tool state
cornerstoneTools.addStackStateManager(canvas, ["stack"]);
cornerstoneTools.addToolState(canvas, "stack", canvasStack);//将工具状态添加到toolStateManager,这由工具以及恢复已保存状态的模块完成。addToolState(element, toolType, measurementData)
cornerstoneTools.stackScrollWheel.activate(canvas); // Mouse wheel
// cornerstoneTools.scrollIndicator.enable(canvas); // Position indicator
// Mouse
cornerstoneTools.wwwc.activate(canvas, 1); // left click
cornerstoneTools.pan.activate(canvas, 2); // middle click
cornerstoneTools.zoom.activate(canvas, 4); // right click
// Touch / Gesture
cornerstoneTools.wwwcTouchDrag.activate(canvas); // - Drag
cornerstoneTools.zoomTouchPinch.activate(canvas); // - Pinch
cornerstoneTools.panMultiTouch.activate(canvas); // - Multi (x2)
// cornerstoneTools.zoomWheel.activate(canvas);
}
</script>
</html>
cornerstoneTools 作用,用法,api使用心得的更多相关文章
- c++用法的学习心得
关于C++这门课,是我在大一的时候开始学习的,那时候接触的就是单纯的一些C++的基本语法规则,基本的编程规则.但是我们都有这样的困惑:课堂和教材的 内容基本上都能接受和理解,但真要实际动手编写程序又感 ...
- asp.net mvc短信接口调用——阿里大于API开发心得
互联网上有许多公司提供短信接口服务,诸如网易云信.阿里大于等等.我在自己项目里需要使用到短信服务起到通知作用,实际开发周期三天,完成配置.开发和使用,总的说,阿里大于提供的接口易于开发,非常的方便,短 ...
- 百度api使用心得体会
最近项目中在使用百度地图api,对于其中的一些有用的点做一些归纳整理,如有不对的地方,欢迎各位大神纠正指出. 一定要学会查找百度地图api提供的类参考网站:http://lbsyun.baidu.co ...
- 关于C++用法的学习心得
通过大一一学期对C++语言的学习,我感觉c++是一门有一定难度并且很有挑战性的科目,在c++学习过程中,我们懂得了其有很多的用法. 引用是C++引入的新语言特性,是C++常用的一个重要内容之一,正确. ...
- Object,String,StringBuffer,StringBuilder,System,Runtime,Date,Math介绍及用法(API)
1 Object对象 面向对象的核心思想:“找合适的对象,做适合的事情”. 合适的对象: 自己描述类,自己创建对象. sun已经描述了好多常用的类,可以使用这些类创建对象. API(App ...
- Android Camera Api的心得
(一) 前言最近看Camera的api,觉得写的真的不错.现在翻译过来,给大家分享分享,译文可能不太好,大家将就着看哈. (二) 正文1. CameraCamera是Android framework ...
- 乐卡上海网点地图制作心得 | 百度地图API使用心得
前言 事情的起因是我的爱人喜欢收集一些美丽的乐卡(明信片的一种,正面是美丽壮阔的风景照).作为一个坚实的后盾自然要支持她!于是我经常借着午休穿梭在大街小巷,凭借乐卡官方提供的乐卡网点地址进行寻找并取卡 ...
- odoo 装饰器用法@api
摘自:blog.csdn.net/cmzhuang/article/details/52932883 @api.one one装饰符自动遍历记录集,把self重新定义成当前记录.注意,返回值是一个li ...
- 百度OCR文字识别API使用心得===com.baidu.ocr.sdk.exception.SDKError[283604]
异常com.baidu.ocr.sdk.exception.SDKError[283604]App identifier unmatch.错误的packname或bundleId.logId::303 ...
随机推荐
- 「Elasticsearch」SpringBoot快速集成ES
Elastic Search 的底层是开源库 Lucene.但是Lucene的使用门槛比较高,必须自己写代码去调用它的接口.而Elastic Search的出现正是为了解决了这个问题,它是 Lucen ...
- python-列表list和元组tuple
list Python内置的一种数据类型是列表:list.list是一种有序的集合,可以随时添加和删除其中的元素. 比如,列出班里所有同学的名字,就可以用一个list表示: >>> ...
- CloudIDE插件开发实战:教你如何调试代码
摘要:今天我们来重点介绍下CloudIDE插件的调试技巧,在插件开发过程中调试作为重要的问题分析和定位手段能够有效帮助开发者提升插件质量. 今天文章中的样例工程我们继续以上一篇<实战CloudI ...
- 【题解】「CF675A」Infinite Sequence
我用的是:分类讨论+暴力 其中分类讨论中,我用了一种namespace名命名空间.如果: \(c = 0\) : 当 \(a == b\) 时,输出 \(YES\) 否则 \(NO\) \(c < ...
- rocketMq指定broker ip地址,适合解决云主机部署问题
在工作中遇到了一个这个问题,就是我们rocketmq是部署在云主机上的 但是我们的开发同事在自己的电脑连接rocketmq链接不上 报错显示Caused by: org.apache.rocket ...
- js v-if 判断多个属性 in
js v-if 判断 <div v-if="suborder.approve_user==user_id || suborder.approve_userrole_id in rol ...
- 持续引领大数据行业发展,腾讯云发布全链路数据开发平台WeData
9月11日,在腾讯全球数字生态大会大数据专场上,腾讯云大数据产品副总经理雷小平重磅发布了全链路数据开发平台WeData,同时发布和升级了流计算服务.云数据仓库.ES.企业画像等6款核心产品,进一步优化 ...
- Maven项目中配置jdk版本
<build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> ...
- 浅谈强连通分量(Tarjan)
强连通分量\(\rm (Tarjan)\) --作者:BiuBiu_Miku \(1.\)一些术语 · 无向图:指的是一张图里面所有的边都是双向的,好比两个人打电话 \(U ...
- Eureka 集群Demo
由于自己遇到了一些eureka集群疑问,就自己搭了一个集群demo进行测试.测试中通过两个eureka相互注册形成集群,两个服务提供者向eureka中注册服务,两个服务消费者通过feign进行服务调用 ...