-
Notifications
You must be signed in to change notification settings - Fork 0
/
mpi_plot.cpp
89 lines (80 loc) · 2.58 KB
/
mpi_plot.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#pragma comment(linker, "/manifestdependency:\"type='win32' name='Microsoft.Windows.Common-Controls' version='6.0.0.0' processorArchitecture='x86' publicKeyToken='6595b64144ccf1df' language='*'\"")
#include <windows.h>
#include <vector>
#include <fstream>
#include <algorithm>
using namespace std;
LRESULT CALLBACK WndProc(HWND hwnd, UINT iMsg, WPARAM wParam, LPARAM lParam);
vector<double> v;
double _max, _min;
int Nx = 200;
int Ny = 100;
const int cellLength = 8;
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, PSTR szCmdLine, int iCmdShow)
{
static wchar_t szAppName[] = L"Window";
HWND hwnd;
MSG msg;
WNDCLASSEX wndclass;
ifstream in("C:\\plot", ios::binary);
//in.read((char*)&Nx, sizeof(Nx));
//in.read((char*)&Ny, sizeof(Ny));
v.resize(Nx * Ny);
in.read((char*)&v[0], Nx * Ny * sizeof(double));
_max = *max_element(v.begin(), v.end());
_min = *min_element(v.begin(), v.end());
vector<vector<double>> vv(Ny);
for (int i = 0; i < Ny; i++)
vv[i] = vector<double>(v.begin() + i * Nx, v.begin() + i * Nx + Nx);
wndclass.cbSize = sizeof(wndclass);
wndclass.style = CS_HREDRAW | CS_VREDRAW;
wndclass.lpfnWndProc = WndProc;
wndclass.cbClsExtra = 0;
wndclass.cbWndExtra = 0;
wndclass.hInstance = hInstance;
wndclass.hIcon = LoadIcon(NULL, IDI_APPLICATION);
wndclass.hCursor = LoadCursor(NULL, IDC_ARROW);
wndclass.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH);
wndclass.lpszMenuName = NULL;
wndclass.lpszClassName = szAppName;
wndclass.hIconSm = LoadIcon(NULL, IDI_APPLICATION);
RegisterClassEx(&wndclass);
hwnd=CreateWindow(szAppName, L"Window", WS_OVERLAPPEDWINDOW, CW_USEDEFAULT,
CW_USEDEFAULT, Nx * cellLength + 20, Ny * cellLength + 40, NULL, NULL, hInstance, NULL);
ShowWindow(hwnd, iCmdShow);
UpdateWindow(hwnd);
while (GetMessage(&msg, NULL, 0, 0))
{
TranslateMessage(&msg);
DispatchMessage(&msg);
}
return msg.wParam;
}
LRESULT CALLBACK WndProc(HWND hwnd, UINT iMsg, WPARAM wParam, LPARAM lParam)
{
HDC hdc;
PAINTSTRUCT ps;
switch(iMsg)
{
case WM_CREATE:
return 0;
case WM_PAINT:
hdc = BeginPaint(hwnd, &ps);
for (int i = 0; i < Ny; i++)
for (int j = 0; j < Nx; j++)
{
int c = 255 - 255 * pow((v[i * Nx + j] - _min) / (_max - _min), .5);
SelectObject(hdc, GetStockObject(NULL_PEN));
HBRUSH br = CreateSolidBrush(RGB(255 - c, 0, c));
SelectObject(hdc, br);
Rectangle(hdc, cellLength * j, cellLength * i, cellLength * (j + 1) + 1, cellLength * (i + 1) + 1);
DeleteObject(br);
}
EndPaint(hwnd, &ps);
return 0;
case WM_DESTROY:
PostQuitMessage(0);
return 0;
}
return DefWindowProc(hwnd, iMsg, wParam, lParam);
}