📄 wksp_grid.cpp
字号:
///////////////////////////////////////////////////////////
// //
// SAGA //
// //
// System for Automated Geoscientific Analyses //
// //
// User Interface //
// //
// Program: SAGA //
// //
//-------------------------------------------------------//
// //
// WKSP_Grid.cpp //
// //
// Copyright (C) 2005 by Olaf Conrad //
// //
//-------------------------------------------------------//
// //
// This file is part of 'SAGA - System for Automated //
// Geoscientific Analyses'. SAGA is free software; you //
// can redistribute it and/or modify it under the terms //
// of the GNU General Public License as published by the //
// Free Software Foundation; version 2 of the License. //
// //
// SAGA is distributed in the hope that it will be //
// useful, but WITHOUT ANY WARRANTY; without even the //
// implied warranty of MERCHANTABILITY or FITNESS FOR A //
// PARTICULAR PURPOSE. See the GNU General Public //
// License for more details. //
// //
// You should have received a copy of the GNU General //
// Public License along with this program; if not, //
// write to the Free Software Foundation, Inc., //
// 59 Temple Place - Suite 330, Boston, MA 02111-1307, //
// USA. //
// //
//-------------------------------------------------------//
// //
// contact: Olaf Conrad //
// Institute of Geography //
// University of Goettingen //
// Goldschmidtstr. 5 //
// 37077 Goettingen //
// Germany //
// //
// e-mail: oconrad@saga-gis.org //
// //
///////////////////////////////////////////////////////////
//---------------------------------------------------------
///////////////////////////////////////////////////////////
// //
// //
// //
///////////////////////////////////////////////////////////
//---------------------------------------------------------
#include <wx/dc.h>
#include <wx/dcmemory.h>
#include <wx/image.h>
#include <wx/filename.h>
#include "res_commands.h"
#include "res_dialogs.h"
#include "helper.h"
#include "dc_helper.h"
#include "active.h"
#include "active_attributes.h"
#include "wksp_map_control.h"
#include "wksp_layer_classify.h"
#include "wksp_layer_legend.h"
#include "wksp_grid.h"
#include "view_scatterplot.h"
///////////////////////////////////////////////////////////
// //
// //
// //
///////////////////////////////////////////////////////////
//---------------------------------------------------------
CWKSP_Grid::CWKSP_Grid(CSG_Grid *pGrid)
: CWKSP_Layer(pGrid)
{
m_pGrid = pGrid;
m_Sel_xN = -1;
Create_Parameters();
}
//---------------------------------------------------------
CWKSP_Grid::~CWKSP_Grid(void)
{
}
///////////////////////////////////////////////////////////
// //
// //
// //
///////////////////////////////////////////////////////////
//---------------------------------------------------------
wxString CWKSP_Grid::Get_Name(void)
{
return( wxString::Format(wxT("%02d. %s"), 1 + Get_ID(), m_pGrid->Get_Name()) );
}
//---------------------------------------------------------
wxString CWKSP_Grid::Get_Description(void)
{
wxString s;
//-----------------------------------------------------
s.Append(wxString::Format(wxT("<b>%s</b><table border=\"0\">"),
LNG("[CAP] Grid")
));
s.Append(wxString::Format(wxT("<tr><td>%s</td><td>%s</td></tr>"),
LNG("[CAP] Name") , m_pGrid->Get_Name()
));
s.Append(wxString::Format(wxT("<tr><td>%s</td><td>%s</td></tr>"),
LNG("[CAP] File") , m_pGrid->Get_File_Name()
));
s.Append(wxString::Format(wxT("<tr><td>%s</td><td>%d (x) * %d (y) = %ld</td></tr>"),
LNG("[CAP] Number of cells") , m_pGrid->Get_NX(), m_pGrid->Get_NY(), m_pGrid->Get_NCells()
));
s.Append(wxString::Format(wxT("<tr><td>%s</td><td>%f</td></tr>"),
LNG("[CAP] Cell size") , m_pGrid->Get_Cellsize()
));
s.Append(wxString::Format(wxT("<tr><td>%s</td><td>[%f] - [%f] = [%f]</td></tr>"),
LNG("[CAP] East/West") , m_pGrid->Get_XMin(), m_pGrid->Get_XMax(), m_pGrid->Get_XRange()
));
s.Append(wxString::Format(wxT("<tr><td>%s</td><td>[%f] - [%f] = [%f]</td></tr>"),
LNG("[CAP] South/North") , m_pGrid->Get_YMin(), m_pGrid->Get_YMax(), m_pGrid->Get_YRange()
));
s.Append(wxString::Format(wxT("<tr><td>%s</td><td>%s</td></tr>"),
LNG("[CAP] Value Type") , gSG_Grid_Type_Names[m_pGrid->Get_Type()]
));
s.Append(wxString::Format(wxT("<tr><td>%s</td><td>[%f] - [%f] = [%f]</td></tr>"),
LNG("[CAP] Value Range") , m_pGrid->Get_ZMin(), m_pGrid->Get_ZMax(), m_pGrid->Get_ZRange()
));
s.Append(wxString::Format(wxT("<tr><td>%s</td><td>%f</td></tr>"),
LNG("[CAP] Arithmetic Mean") , m_pGrid->Get_ArithMean(true)
));
s.Append(wxString::Format(wxT("<tr><td>%s</td><td>%f</td></tr>"),
LNG("[CAP] Standard Deviation") , sqrt(m_pGrid->Get_Variance(true))
));
s.Append(wxString::Format(wxT("<tr><td>%s</td><td>%fMB</td></tr>"),
LNG("[CAP] Memory Size") , (double)(m_pGrid->Get_NCells() * m_pGrid->Get_nValueBytes()) / N_MEGABYTE_BYTES
));
if( m_pGrid->is_Compressed() )
{
s.Append(wxString::Format(wxT("<tr><td>%s</td><td>%f%%</td></tr>"),
LNG("[CAP] Memory Compression") , 100.0 * m_pGrid->Get_Compression_Ratio()
));
}
if( m_pGrid->is_Cached() )
{
s.Append(wxString::Format(wxT("<tr><td>%s</td><td>%s = %fmb</td></tr>"),
LNG("[CAP] File cache activated") , LNG("buffer size"), m_pGrid->Get_Buffer_Size() / (double)N_MEGABYTE_BYTES
));
}
s.Append(wxT("</table>"));
//-----------------------------------------------------
s.Append(wxString::Format(wxT("<hr><b>%s</b><font size=\"-1\">"), LNG("[CAP] Data History")));
s.Append(m_pGrid->Get_History().Get_HTML());
s.Append(wxString::Format(wxT("</font")));
return( s );
}
//---------------------------------------------------------
wxMenu * CWKSP_Grid::Get_Menu(void)
{
wxMenu *pMenu;
pMenu = new wxMenu(m_pGrid->Get_Name());
CMD_Menu_Add_Item(pMenu, false, ID_CMD_WKSP_ITEM_CLOSE);
CMD_Menu_Add_Item(pMenu, false, ID_CMD_GRIDS_SAVE);
CMD_Menu_Add_Item(pMenu, false, ID_CMD_GRIDS_SAVEAS);
CMD_Menu_Add_Item(pMenu, false, ID_CMD_GRIDS_SAVEAS_IMAGE);
CMD_Menu_Add_Item(pMenu, false, ID_CMD_GRIDS_SHOW);
pMenu->AppendSeparator();
CMD_Menu_Add_Item(pMenu, true , ID_CMD_GRIDS_HISTOGRAM);
CMD_Menu_Add_Item(pMenu, false, ID_CMD_GRIDS_SCATTERPLOT);
CMD_Menu_Add_Item(pMenu, false, ID_CMD_GRIDS_EQUALINTERVALS);
return( pMenu );
}
///////////////////////////////////////////////////////////
// //
// //
// //
///////////////////////////////////////////////////////////
//---------------------------------------------------------
bool CWKSP_Grid::On_Command(int Cmd_ID)
{
wxString File_Path;
switch( Cmd_ID )
{
default:
return( CWKSP_Layer::On_Command(Cmd_ID) );
case ID_CMD_GRIDS_SAVEAS_IMAGE:
_Save_Image();
break;
case ID_CMD_GRIDS_HISTOGRAM:
Histogram_Toggle();
break;
case ID_CMD_GRIDS_SCATTERPLOT:
Add_ScatterPlot(Get_Grid());
break;
case ID_CMD_GRIDS_EQUALINTERVALS:
m_pClassify->Metric2EqualElements();
break;
}
return( true );
}
//---------------------------------------------------------
bool CWKSP_Grid::On_Command_UI(wxUpdateUIEvent &event)
{
switch( event.GetId() )
{
default:
return( CWKSP_Layer::On_Command_UI(event) );
case ID_CMD_GRIDS_HISTOGRAM:
event.Check(m_pHistogram != NULL);
break;
}
return( true );
}
///////////////////////////////////////////////////////////
// //
// //
// //
///////////////////////////////////////////////////////////
//---------------------------------------------------------
void CWKSP_Grid::On_Create_Parameters(void)
{
//-----------------------------------------------------
// General...
m_Parameters.Add_String(
m_Parameters("NODE_GENERAL") , "GENERAL_Z_UNIT" , LNG("[CAP] Unit"),
LNG(""),
m_pGrid->Get_Unit()
);
m_Parameters.Add_Value(
m_Parameters("NODE_GENERAL") , "GENERAL_Z_FACTOR" , LNG("[CAP] Z-Factor"),
LNG(""),
PARAMETER_TYPE_Double
);
m_Parameters.Add_Range(
m_Parameters("NODE_GENERAL") , "GENERAL_Z_NODATA" , LNG("[CAP] No Data"),
LNG("")
);
//-----------------------------------------------------
// Memory...
m_Parameters.Add_Node(
NULL , "NODE_MEMORY" , LNG("[CAP] Memory"),
LNG("")
);
m_Parameters.Add_Choice(
m_Parameters("NODE_MEMORY") , "MEMORY_MODE" , LNG("[CAP] Memory Handling"),
LNG(""),
wxString::Format(wxT("%s|%s|%s|"),
LNG("[VAL] Normal"),
LNG("[VAL] RTL Compression"),
LNG("[VAL] File Cache")
), 0
);
m_Parameters.Add_Value(
m_Parameters("NODE_MEMORY") , "MEMORY_BUFFER_SIZE" , LNG("[CAP] Buffer Size MB"),
LNG(""),
PARAMETER_TYPE_Double
);
//-----------------------------------------------------
// Display...
m_Parameters.Add_Value(
m_Parameters("NODE_DISPLAY") , "DISPLAY_TRANSPARENCY" , LNG("[CAP] Transparency [%]"),
LNG(""),
PARAMETER_TYPE_Double, 0.0, 0.0, true, 100.0, true
);
m_Parameters.Add_Choice(
m_Parameters("NODE_DISPLAY") , "DISPLAY_INTERPOLATION" , LNG("[CAP] Interpolation"),
LNG(""),
wxString::Format(wxT("%s|%s|%s|%s|%s|"),
LNG("[VAL] None"),
LNG("[VAL] Bilinear"),
LNG("[VAL] Inverse Distance"),
LNG("[VAL] Bicubic Spline"),
LNG("[VAL] B-Spline")
), 0
);
//-----------------------------------------------------
// Classification...
((CSG_Parameter_Choice *)m_Parameters("COLORS_TYPE")->Get_Data())->Set_Items(
wxString::Format(wxT("%s|%s|%s|%s|%s|"),
LNG("[VAL] Unique Symbol"),
LNG("[VAL] Lookup Table"),
LNG("[VAL] Graduated Color"),
LNG("[VAL] RGB"),
LNG("[VAL] Shade")
)
);
m_Parameters("COLORS_TYPE")->Set_Value(CLASSIFY_METRIC);
//-----------------------------------------------------
// Cell Values...
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -