以下は、app.config ファイル内の接続文字列です。データソースで指定されたパスに注意してください。
<?xml version="1.0"?>
<configuration>
<connectionStrings>
<add name="ConnString" connectionString="Provider=Microsoft.ACE.OLEDB.12.0;Data Source=..\..\Database\ProductsDatabase.accdb;Persist Security Info=False;" providerName="System.Data.SqlClient"/>
</connectionStrings>
</configuration>
アプリケーションには、MouseDoubleclick イベントを持つボタン コントロール内にイメージ コントロールがあります。
<Button Name="m_oBtnProductImage" Grid.Column="0" Height="60" Width="60" Background="LightGray" Style="{x:Null}" MouseDoubleClick="m_oBtnProductImage_MouseDoubleClick">
<Image Tag="Image" Name="m_oImage" Stretch="Fill" Source="{Binding SelectedProductEn.ProductImage}"></Image>
</Button>
MouseDoubleclick イベント ハンドラーには、新しい画像を参照してアップロードし、データベースで同じ画像を更新する機能があります。
private void m_oBtnProductImage_MouseDoubleClick(object sender, RoutedEventArgs e)
{
Bitmap oBitmapImage = null;
OpenFileDialog oBrowseImageFile = new OpenFileDialog();
oBrowseImageFile.Filter = "Image Files(*.jpg; *.jpeg; *.gif; *.bmp)|*.jpg; *.jpeg; *.gif; *.bmp";
if (oBrowseImageFile.ShowDialog() == true)
{
System.Windows.Controls.Image oPictureBox = ((Button)sender).FindName("m_oImage") as System.Windows.Controls.Image;
string sImagePath = oBrowseImageFile.FileName;
oBitmapImage = new Bitmap(sImagePath);
((CMainUIViewModel)this.DataContext).SelectedProductEn.ProductImage = (byte[])TypeDescriptor.GetConverter(oBitmapImage).ConvertTo(oBitmapImage, typeof(byte[]));
((CMainUIViewModel)this.DataContext).UpdateModifiedProduct(((CMainUIViewModel)this.DataContext).SelectedProductEn);
}
}
アプリケーションの UI から画像を参照すると、データソースで指定されたパスが参照された画像ファイルのパスに変更されるため、データベースが見つからないという例外がスローされます。
適切な変更を行うために必要な提案。