热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

VTK求灰度图和直方图

实现效果:  代码如下:doubleleftview[4]{0,0,0.33,1};doublemidview[4]{0.33,0,0.66,1};doublerightview[

实现效果:

 

 

代码如下:

double leftview[4] = {0,0, 0.33,1};
double midview[4] = {0.33,0, 0.66,1};
double rightview[4] = {0.66,0, 1.0,1};
int bins = 256;
int comps = 1;
vtkSmartPointer
reader = vtkSmartPointer::New();
reader
->SetFileName("d:/lena.jpg");
reader
->Update();
vtkSmartPointer
actor1 = vtkSmartPointer::New();
actor1
->GetMapper()->SetInputConnection(reader->GetOutputPort());
vtkSmartPointer
render1 = vtkSmartPointer::New();
render1
->AddActor(actor1);
render1
->SetViewport(leftview);
render1
->ResetCamera();
render1
->SetBackground(0,1,0);
vtkSmartPointer
lum = vtkSmartPointer::New();
lum
->SetInputConnection(reader->GetOutputPort());
lum
->Update();
vtkSmartPointer
actorgray = vtkSmartPointer::New();
actorgray
->GetMapper()->SetInputConnection(lum->GetOutputPort());
vtkSmartPointer
rendergray = vtkSmartPointer::New();
rendergray
->AddActor(actorgray);
rendergray
->SetViewport(midview);
rendergray
->ResetCamera();
rendergray
->SetBackground(1,0,0);
vtkSmartPointer
his = vtkSmartPointer::New();
his
->SetInputData(lum->GetOutput());
his
->SetComponentExtent(0, bins-1, 0,0,0,0);
his
->SetComponentOrigin(0,0,0);
his
->SetComponentSpacing(256.0/bins, 0,0);
his
->Update();
vtkSmartPointer
freq = vtkSmartPointer::New();
freq
->SetNumberOfComponents(1);
int *output = static_cast<int*>(his->GetOutput()->GetScalarPointer());
for(int j=0; j ){
for(int i=0; i ){
freq->InsertNextTuple1(*output);
output
++;
}
}
vtkSmartPointer
dobj = vtkSmartPointer::New();
dobj
->GetFieldData()->AddArray(freq);
vtkSmartPointer
actor2=vtkSmartPointer::New();
actor2
->SetInput(dobj);
actor2
->SetTitle("histogram");
actor2
->GetProperty()->SetColor(1,1,1);
actor2
->GetLegendActor()->SetNumberOfEntries(dobj->GetFieldData()->GetArray(0)->GetNumberOfTuples());
actor2
->LegendVisibilityOff();
actor2
->LabelVisibilityOff();
double colors[3][3] = {{1,0,0},{0,1,0},{0,0,1}};
for(int i =0;i ){
actor2->SetBarColor(i, colors[0]);
}
vtkSmartPointer
render2 = vtkSmartPointer::New();
render2
->AddActor(actor2);
render2
->SetViewport(rightview);
render2
->ResetCamera();
render2
->SetBackground(0,0,1);
pRenderWindow
->AddRenderer(render1);
pRenderWindow
->AddRenderer(rendergray);
pRenderWindow
->AddRenderer(render2);

 



推荐阅读
  • 导航栏样式练习:项目实例解析
    本文详细介绍了如何创建一个具有动态效果的导航栏,包括HTML、CSS和JavaScript代码的实现,并附有详细的说明和效果图。 ... [详细]
  • 本文介绍了在使用Visual Studio 2015进行项目开发时,遇到类向导弹出“异常来自 HRESULT:0x8CE0000B”错误的解决方案。通过具体步骤和实践经验,帮助开发者快速排查并解决问题。 ... [详细]
  • 作为一名新手,您可能会在初次尝试使用Eclipse进行Struts开发时遇到一些挑战。本文将为您提供详细的指导和解决方案,帮助您克服常见的配置和操作难题。 ... [详细]
  • 在使用 DataGridView 时,如果在当前单元格中输入内容但光标未移开,点击保存按钮后,输入的内容可能无法保存。只有当光标离开单元格后,才能成功保存数据。本文将探讨如何通过调用 DataGridView 的内置方法解决此问题。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 高效提取PDF页面的实用技巧
    在学习和工作中,我们经常需要与他人共享PDF格式的资料。然而,有时只需要分享部分内容,而不仅仅是整个文档。本文将介绍如何使用福昕阅读器领鲜版高效地提取PDF页面,以提高文件传输效率和查阅便捷性。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文介绍如何通过创建替代插入触发器,使对视图的插入操作能够正确更新相关的基本表。涉及的表包括:飞机(Aircraft)、员工(Employee)和认证(Certification)。 ... [详细]
  • MacOS上高效的SVN管理工具Cornerstone安装指南
    本文详细介绍如何在MacOS上安装和配置高效SVN管理工具Cornerstone,涵盖其主要功能和优化后的性能提升。 ... [详细]
  • 帝国CMS多图上传插件详解及使用指南
    本文介绍了一款用于帝国CMS的多图上传插件,该插件通过Flash技术实现批量图片上传功能,显著提升了多图上传效率。文章详细说明了插件的安装、配置和使用方法。 ... [详细]
  • 本教程涵盖OpenGL基础操作及直线光栅化技术,包括点的绘制、简单图形绘制、直线绘制以及DDA和中点画线算法。通过逐步实践,帮助读者掌握OpenGL的基本使用方法。 ... [详细]
  • 本文详细介绍了 com.facebook.drawee.view.SimpleDraweeView 中的 setScaleType 方法,提供了多个实际代码示例,并解释了其在不同场景下的应用。 ... [详细]
  • 基因组浏览器中的Wig格式解析
    本文详细介绍了Wiggle(Wig)格式及其在基因组浏览器中的应用,涵盖variableStep和fixedStep两种主要格式的特点、适用场景及具体使用方法。同时,还提供了关于数据值和自定义参数的补充信息。 ... [详细]
author-avatar
曹莹888淑女
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有