Передача методов на трекбар
Это задание.
Я создаю очень простую программу обработки изображений в C#, которая позволяет пользователю выполнять определенные действия с изображением в оттенках серого.
Проблема, с которой я сейчас сталкиваюсь, заключается в том, что мне нужно, чтобы на трекбар было передано несколько методов. Это позволило бы трекбару изменить пороговое значение для любого вызванного метода.
Я искал в Google, но, похоже, этой проблемы очень мало. Так может кто-нибудь дать мне совет, как это сделать, пожалуйста?
Код, который у меня сейчас есть, такой.
using System;
using System.Collections.Generic;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Drawing.Imaging;
using System.IO;
using System.Text;
using System.Windows.Forms;
namespace DIP_START
{
public partial class Form1 : Form
{
public Bitmap original_image, proc_image;
public int[] bins = new int[256];
int max;
public Form1()
{
InitializeComponent();
original_image = null;
proc_image = null;
}
private void Form1_Load(object sender, EventArgs e)
{
}
public void Form1_Paint(object sender, PaintEventArgs e)
{
if (original_image != null)
{
Graphics g = e.Graphics;
Rectangle r = new Rectangle(10, 50, original_image.Width, original_image.Height);
g.DrawImage(original_image, r);
}
}
// OPEN IMAGE FILE
/******************************************************************************************/
private void openToolStripMenuItem_Click_1(object sender, EventArgs e)
{
// show the openFile dialog box
Graphics g = this.CreateGraphics();
if (openFileDialog1.ShowDialog() == DialogResult.OK)
{
original_image = new Bitmap(openFileDialog1.FileName);
}
Rectangle r = new Rectangle(10, 50, original_image.Width, original_image.Height);
g.DrawImage(original_image, r);
}
// EXIT APPLICATION
/************************************************************************************/
private void exitToolStripMenuItem_Click_1(object sender, EventArgs e)
{
Dispose();
Application.Exit();
}
/***********************************************************************************/
// EDGE DETECTION
/***********************************************************************************/
/***********************************************************************************/
// ROBERTS GRADIENT - WITH THRESHOLD
/***********************************************************************************/
private void withoutToolStripMenuItem_Click(object sender, System.EventArgs e)
{
Graphics g = this.CreateGraphics();
int width = original_image.Width - 1;
int height = original_image.Height - 1;
int threshold = thresholdBar1.Value;
thresholdBar1.Visible = true;
thresholdValueBox.Visible = true;
string thresholdBarVal = Convert.ToString(thresholdBar1.Value);
thresholdValueBox.Text = thresholdBarVal;
Rectangle r = new Rectangle(535, 50, original_image.Width, original_image.Height);
Rectangle r2 = new Rectangle(0, 0, original_image.Width, original_image.Height);
proc_image = original_image.Clone(r2, PixelFormat.Format8bppIndexed);
g.DrawImage(original_image, r2);
BitmapData bmDataOR = original_image.LockBits(new Rectangle(0, 0, width, height), ImageLockMode.ReadWrite, PixelFormat.Format8bppIndexed);
BitmapData bmDataPR = proc_image.LockBits(new Rectangle(0, 0, width, height), ImageLockMode.ReadWrite, PixelFormat.Format8bppIndexed);
int stride = bmDataOR.Stride;
// System.IntPtr Scan0 = bmData.Scan0;
unsafe
{
byte* o = (byte*)(void*)bmDataOR.Scan0;
byte* p = (byte*)(void*)bmDataPR.Scan0;
byte[] pix_val = new byte[4];
for (int y = 0; y < height; ++y)
{
for (int x = 0; x < width; ++x)
{
pix_val[0] = o[y * stride + x];
pix_val[1] = o[(y + 1) * stride + x + 1];
pix_val[2] = o[(y + 1) * stride + x];
pix_val[3] = o[y * stride + x + 1];
int new_pix_val = Math.Abs(pix_val[0] - pix_val[1]) + Math.Abs(pix_val[2] - pix_val[3]);
if (new_pix_val > threshold)
{
p[y * stride + x] = 255;
}
else
p[y * stride + x] = 0;
}
}
proc_image.UnlockBits(bmDataPR);
original_image.UnlockBits(bmDataOR);
g.DrawImage(proc_image, r);
//thresholdBar1.Visible = false;
}
}
/***********************************************************************************/
// NEIGHBOURHOOD AVERAGING WITHOUT THRESHOLD
/***********************************************************************************/
private void withoutThresholdToolStripMenuItem_Click(object sender, System.EventArgs e)
{
Graphics g = this.CreateGraphics();
int width = original_image.Width - 2;
int height = original_image.Height - 2;
int total_val = 0;
int avg = 0;
Rectangle r = new Rectangle(535, 50, original_image.Width, original_image.Height);
Rectangle r2 = new Rectangle(0, 0, original_image.Width, original_image.Height);
proc_image = original_image.Clone(r2, PixelFormat.Format8bppIndexed);
BitmapData bmDataOR = original_image.LockBits(new Rectangle(0, 0, width, height), ImageLockMode.ReadWrite, PixelFormat.Format8bppIndexed);
BitmapData bmDataPR = proc_image.LockBits(new Rectangle(0, 0, width, height), ImageLockMode.ReadWrite, PixelFormat.Format8bppIndexed);
int stride = bmDataOR.Stride;
unsafe
{
byte* o = (byte*)(void*)bmDataOR.Scan0;
byte* p = (byte*)(void*)bmDataPR.Scan0;
byte[] pix_val = new byte[9];
for (int y = 0; y < height; ++y)
{
for (int x = 0; x < width; ++x)
{
pix_val[0] = o[y * stride + x];
pix_val[1] = o[y * stride + x + 1];
pix_val[2] = o[y * stride + x + 2];
pix_val[3] = o[(y + 1) * stride + x];
pix_val[4] = o[(y + 1) * stride + x + 1];
pix_val[5] = o[(y + 1) * stride + x + 2];
pix_val[6] = o[(y + 2) * stride + x];
pix_val[7] = o[(y + 2) * stride + x + 1];
pix_val[8] = o[(y + 2) * stride + x + 2];
for (int i = 0; i < 9; ++i)
{
total_val = total_val + pix_val[i];
}
avg = total_val / 9;
p[y * stride + x] = (byte)avg;
total_val = 0;
}
}
proc_image.UnlockBits(bmDataPR);
original_image.UnlockBits(bmDataOR);
g.DrawImage(proc_image, r);
}
}
}
}
Как вы можете видеть, трекбар жестко запрограммирован в градиенте Робертса, и мне нужно усреднение по соседству, чтобы использовать и трекбар.
В Visual Studio под заголовком "События" для трекбара я вставил метод для градиента Робертса.