-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathShowMLPlot.cs
58 lines (53 loc) · 1.7 KB
/
ShowMLPlot.cs
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
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using MLCreateImageNative;
namespace ShowMATLABImage
{
public partial class ShowMLPlot : Form
{
private CCreateImage _createImage = null;
public CCreateImage createImage
{
get {
if (_createImage == null)
_createImage = new CCreateImage();
return _createImage;
}
}
public ShowMLPlot()
{
InitializeComponent();
}
/// <summary>
/// een afbeelding van Matlab met de beroepmde differentiaalvergelijking die het logo
/// van Matlab weergeeft plotten met opgegeven maasaantal
/// </summary>
/// <param name="gridSize">maasaantal</param>
public void UpdateGraphic(double gridSize)
{
object[] ans = createImage.GimmePeaks(3, gridSize);
int width = (int)((double[,])ans[1])[0, 0];
int height = (int)((double[,])ans[2])[0, 0];
byte[,] mlImg = (byte[,])ans[0];
DirectBitmap _dbmGraphic = new DirectBitmap(width, height);
byte[] img = mlImg.Cast<byte>().ToArray();
_dbmGraphic.SetBytes(img);
pbGraph.Image = _dbmGraphic.Bitmap;
}
private void Form1_Load(object sender, EventArgs e)
{
UpdateGraphic((double)nudGridSize.Value);
}
private void numericUpDown1_ValueChanged(object sender, EventArgs e)
{
UpdateGraphic((double)nudGridSize.Value);
}
}
}