首页 > 其他分享 >VTK 实例31:灰度图像直方图

VTK 实例31:灰度图像直方图

时间:2023-08-15 11:48:08浏览次数:51  
标签:int VTK histogram vtkSmartPointer barChart 直方图 灰度 New include

  1 #include "vtkAutoInit.h" 
  2 VTK_MODULE_INIT(vtkRenderingOpenGL2);
  3 VTK_MODULE_INIT(vtkInteractionStyle);
  4 
  5 #include <vtkActor.h>
  6 #include <vtkBarChartActor.h>
  7 #include <vtkFieldData.h>
  8 #include <vtkImageAccumulate.h>
  9 #include <vtkImageData.h>
 10 #include <vtkIntArray.h>
 11 #include <vtkJPEGReader.h>
 12 #include <vtkLegendBoxActor.h>
 13 #include <vtkProperty2D.h>
 14 #include <vtkRenderer.h>
 15 #include <vtkRenderWindow.h>
 16 #include <vtkRenderWindowInteractor.h>
 17 #include <vtkSmartPointer.h>
 18 #include <vtkTextProperty.h>
 19 
 20 //测试图像:../data/lena-gray.jpg
 21 int main(int argc, char* argv[])
 22 {
 23 
 24     vtkSmartPointer<vtkJPEGReader> reader =
 25         vtkSmartPointer<vtkJPEGReader>::New();
 26     reader->SetFileName ( "lena-gray.jpg" );
 27     reader->Update();
 28 
 29     int bins   = 16;
 30     int comps  = 1;
 31 
 32     vtkSmartPointer<vtkImageAccumulate> histogram =
 33         vtkSmartPointer<vtkImageAccumulate>::New();
 34     histogram->SetInputData(reader->GetOutput());
 35     histogram->SetComponentExtent(0, bins-1, 0, 0, 0, 0);
 36     histogram->SetComponentOrigin(0, 0, 0);
 37     histogram->SetComponentSpacing(256.0/bins, 0, 0);
 38     histogram->Update();
 39 
 40     int* output = static_cast<int*>(histogram->GetOutput()->GetScalarPointer());
 41 
 42     vtkSmartPointer<vtkIntArray> frequencies = 
 43         vtkSmartPointer<vtkIntArray>::New();
 44     frequencies->SetNumberOfComponents(1);
 45 
 46     for(int j = 0; j < bins; ++j)
 47     {
 48         for(int i=0; i<comps; i++)
 49         {
 50             frequencies->InsertNextTuple1(*output++);
 51         }
 52     }
 53 
 54     vtkSmartPointer<vtkDataObject> dataObject = 
 55         vtkSmartPointer<vtkDataObject>::New();
 56     dataObject->GetFieldData()->AddArray( frequencies );
 57 
 58     vtkSmartPointer<vtkBarChartActor> barChart = 
 59         vtkSmartPointer<vtkBarChartActor>::New();
 60     barChart->SetInput(dataObject);
 61     barChart->SetTitle("Histogram");
 62     barChart->GetPositionCoordinate()->SetValue(0.05,0.05,0.0);
 63     barChart->GetPosition2Coordinate()->SetValue(0.95,0.95,0.0);
 64     barChart->GetProperty()->SetColor(0,0,0);
 65     barChart->GetTitleTextProperty()->SetColor(0,0,0);
 66     barChart->GetLabelTextProperty()->SetColor(0,0,0);
 67     barChart->GetLegendActor()->SetNumberOfEntries(dataObject->GetFieldData()->GetArray(0)->GetNumberOfTuples());
 68     barChart->LegendVisibilityOff();
 69     barChart->LabelVisibilityOff();
 70 
 71     double colors[3][3] = {
 72         { 1, 0, 0 },
 73         { 0, 1, 0 },
 74         { 0, 0, 1 } };
 75 
 76     int count = 0;
 77     for( int i = 0; i < bins; ++i )
 78     {
 79         for( int j = 0; j < comps; ++j )
 80         {
 81             barChart->SetBarColor( count++, colors[j] );
 82         }
 83     }
 84 
 85     vtkSmartPointer<vtkRenderer> renderer = 
 86         vtkSmartPointer<vtkRenderer>::New();
 87     renderer->AddActor(barChart);
 88     renderer->SetBackground(1.0, 1.0, 1.0);
 89 
 90     vtkSmartPointer<vtkRenderWindow> renderWindow = 
 91         vtkSmartPointer<vtkRenderWindow>::New();
 92     renderWindow->AddRenderer(renderer);
 93     renderWindow->SetSize(640, 480);
 94     renderWindow->Render();
 95     renderWindow->SetWindowName("ImageAccumulateExample");
 96 
 97     vtkSmartPointer<vtkRenderWindowInteractor> interactor =
 98         vtkSmartPointer<vtkRenderWindowInteractor>::New();
 99     interactor->SetRenderWindow(renderWindow);
100 
101     interactor->Initialize();
102     interactor->Start();
103 
104     return EXIT_SUCCESS;
105 }

标签:int,VTK,histogram,vtkSmartPointer,barChart,直方图,灰度,New,include
From: https://www.cnblogs.com/ybqjymy/p/17630916.html

相关文章

  • VTK 实例32:图像重采样(降采样)
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkSmartPointer.h>6#include<vtkImageData.h>7#include<vtkImageShiftScale.h>8#include<......
  • VTK 实例33:图像重采样(降和升采样)
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkSmartPointer.h>6#include<vtkImageData.h>7#include<vtkRenderWindow.h>8#include......
  • VTK 实例26:将BMP类型的RGB图像转换为灰度图像
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkSmartPointer.h>6#include<vtkImageData.h>7#include<vtkRenderWindow.h>8#include<vtk......
  • VTK 实例20:用vtkImageViewer2显示三维医学图像mhd的某个切面
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkSmartPointer.h>6#include<vtkImageViewer2.h>7#include<vtkRenderWindow.h>8#include<......
  • VTK 实例6:加入灯光(蓝色背景+白色演员+红色环境光)
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkConeSource.h>//源数据6#include<vtkPolyDataMapper.h>//数据映射7#include<vtkRenderer.h>//绘制器8#......
  • VTK 实例5:设置椎体颜色属性
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkConeSource.h>//源数据6#include<vtkPolyDataMapper.h>//数据映射7#include<vtkRenderer.h>//绘制器8#......
  • VTK 实例7:相机控制
    未加入相机控制时演员位置: 加入相机控制时演员位置(视角为x轴负方向):1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkConeSource.h>//源数据6#include<vtkPolyDataMapper.h>//数据......
  • VTK 实例8:command与observe设计模式(当交互使相机变化时打印出当前相机的坐标,当发生拾
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);4#include<vtkConeSource.h>5#include<vtkPolyDataMapper.h>6#include<vtkRenderer.h>7#include<vtkRende......
  • VTK 实例9:坐标系统1
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);4#include<vtkConeSource.h>//源数据5#include<vtkCubeSource.h>//立方体6#include<vtkPolyDataMapper.h>//数据映射7#in......
  • VTK 实例10:坐标系统2
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);4#include<vtkConeSource.h>//源数据5#include<vtkCubeSource.h>//立方体6#include<vtkPolyDataMapper.h>//数据映射7#in......