Initial Upload
This commit is contained in:
6
example3/compile.sh
Executable file
6
example3/compile.sh
Executable file
@@ -0,0 +1,6 @@
|
||||
#!/bin/bash
|
||||
|
||||
inc=`gmt-config --cflags`
|
||||
lib=`gmt-config --libs`
|
||||
g++ plot_memory.cpp $inc $lib -o plot_memory
|
||||
./plot_memory
|
||||
BIN
example3/plot_memory
Executable file
BIN
example3/plot_memory
Executable file
Binary file not shown.
113
example3/plot_memory.cpp
Normal file
113
example3/plot_memory.cpp
Normal file
@@ -0,0 +1,113 @@
|
||||
#include "gmt.h"
|
||||
#include "stdio.h"
|
||||
#include "unistd.h"
|
||||
#include "iostream"
|
||||
#include "string"
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
std::string cpt_file = "user.cpt";
|
||||
std::string ps_file = "user.ps";
|
||||
|
||||
// Initiate a new GMT session
|
||||
// you need to destroy the session later
|
||||
void *API = GMT_Create_Session("plot_memory_example", 2U, 0, NULL);
|
||||
|
||||
// prepare header info
|
||||
int m = 101, n = 81;
|
||||
double wesn[4] = {0, 100, 0, 80};
|
||||
double inc[2] = {1, 1};
|
||||
// create an empty data container of GMT_GRID type
|
||||
// forcedly convert pointer type (C++ standard)
|
||||
// you need to destroy the data later
|
||||
struct GMT_GRID *G = reinterpret_cast<GMT_GRID*>(
|
||||
GMT_Create_Data(API, GMT_IS_GRID, GMT_IS_SURFACE,
|
||||
GMT_CONTAINER_AND_DATA, NULL, &wesn[0], &inc[0],
|
||||
GMT_GRID_NODE_REG, -1, NULL));
|
||||
|
||||
// manipulate grid data
|
||||
double *x_coord = GMT_Get_Coord(API, GMT_IS_GRID, GMT_X, G);
|
||||
double *y_coord = GMT_Get_Coord(API, GMT_IS_GRID, GMT_Y, G);
|
||||
|
||||
int idx;
|
||||
double minz = 1e+30, maxz = -1e+30;
|
||||
for (int i = 0; i < G->header->n_rows; i++)
|
||||
{
|
||||
for (int j = 0; j < G->header->n_columns; j++)
|
||||
{
|
||||
idx = GMT_Get_Index(API, G->header, i, j);
|
||||
G->data[idx] = x_coord[j] * y_coord[i];
|
||||
|
||||
if (G->data[idx] < minz) minz = G->data[idx];
|
||||
if (G->data[idx] > maxz) maxz = G->data[idx];
|
||||
}
|
||||
}
|
||||
|
||||
G->header->z_min = minz;
|
||||
G->header->z_max = maxz;
|
||||
|
||||
// start the plotting
|
||||
// 1. set GMT defaults
|
||||
std::string args_defaults = "FONT_ANNOT_PRIMARY=10.5p,Times-Roman,black \
|
||||
MAP_FRAME_PEN=thinnest,black \
|
||||
MAP_GRID_PEN_PRIMARY=thinnest,black \
|
||||
MAP_TICK_PEN_PRIMARY=thinnest,black \
|
||||
MAP_TICK_LENGTH_PRIMARY=1p/0.5p \
|
||||
MAP_TITLE_OFFSET=7.5p \
|
||||
MAP_GRID_CROSS_SIZE_PRIMARY=2p \
|
||||
FONT_LABEL=10.5p,Times-Roman,black \
|
||||
MAP_LABEL_OFFSET=5p \
|
||||
MAP_ANNOT_OFFSET_PRIMARY=2.5p";
|
||||
// call gmtset
|
||||
GMT_Call_Module (API, "gmtset", GMT_MODULE_CMD, (char*) args_defaults.c_str());
|
||||
|
||||
// load the grid to a virtual file for plotting
|
||||
char grid_name[GMT_STR16] = {""};
|
||||
GMT_Open_VirtualFile (API, GMT_IS_GRID, GMT_IS_SURFACE, GMT_IN, G, grid_name);
|
||||
// get string type of grid name
|
||||
std::string grid_name_str = grid_name;
|
||||
|
||||
// prepare cpt file
|
||||
std::string args_cpt = grid_name_str + " -Crainbow -R0/100/0/80 -Z -D ->" + cpt_file;
|
||||
// call grd2cpt
|
||||
GMT_Call_Module (API, "grd2cpt", GMT_MODULE_CMD, (char*) args_cpt.c_str());
|
||||
|
||||
// plot the image
|
||||
std::string args_image = grid_name_str + " -R0/100/0/80 -C" + cpt_file +
|
||||
" -Bxag+l\"x (m)\" -Byag+l\"y (m)\" -JX1.5i/1.5i -X0.5i -Y0.5i -K -P --MAP_FRAME_AXES=WesNZ ->" + ps_file;
|
||||
// call grdimage
|
||||
GMT_Call_Module (API, "grdimage", GMT_MODULE_CMD, (char*) args_image.c_str());
|
||||
|
||||
// plot color bar
|
||||
std::string args_bar = "-Dx0.1i/-0.2i+w1.3i/0.05i+h -C" + cpt_file +
|
||||
" -Bxa -By+lm -O -)" + ps_file;
|
||||
// call psscale
|
||||
GMT_Call_Module (API, "psscale", GMT_MODULE_CMD, (char*) args_bar.c_str());
|
||||
|
||||
// convert ps file to raster formats
|
||||
std::string args_pic = ps_file + " -A -TEG -E300";
|
||||
// call psconvert
|
||||
GMT_Call_Module (API, "psconvert", GMT_MODULE_CMD, (char*) args_pic.c_str());
|
||||
|
||||
// close virtual file
|
||||
GMT_Close_VirtualFile (API, grid_name);
|
||||
|
||||
// destroy data container
|
||||
GMT_Destroy_Data(API, G);
|
||||
|
||||
// end the GMT session
|
||||
GMT_Destroy_Session(API);
|
||||
|
||||
// remove temporary files. including GMT defaults
|
||||
remove(cpt_file.c_str());
|
||||
remove(ps_file.c_str());
|
||||
// if exist, delete
|
||||
std::string hist_file = "gmt.history";
|
||||
std::string conf_file = "gmt.conf";
|
||||
if (!access(hist_file.c_str(), F_OK))
|
||||
remove(hist_file.c_str());
|
||||
if (!access(conf_file.c_str(), F_OK))
|
||||
remove(conf_file.c_str());
|
||||
|
||||
return 0;
|
||||
}
|
||||
1041
example3/user.eps
Normal file
1041
example3/user.eps
Normal file
File diff suppressed because it is too large
Load Diff
BIN
example3/user.png
Normal file
BIN
example3/user.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 24 KiB |
Reference in New Issue
Block a user