2017-02-27 5 views
0

私は電話ライブラリからイメージを選択して表示することができました。これがコードです。 Questionはどうやってこの画像をコンタクトのSqliteデータベースに挿入して取得し、画像を取得した後に再び表示するのですか?ここに私のコードです。詳細なステップバイステップの指示はここから理解できます。Windowsの電話機でsqliteデータベースにビットマップイメージを挿入する方法8.1 c#

 namespace Mobile_Life.Pages 
{ 

public sealed partial class NextOFKin_Update_Delete : Page 
    { 
     int Selected_ContactId = 0; 
     DatabaseHelperClass Db_Helper = new DatabaseHelperClass(); 
     Contacts currentcontact = new Contacts(); 
     CoreApplicationView view; 

     public NextOFKin_Update_Delete() 
     { 
      this.InitializeComponent(); 
      HardwareButtons.BackPressed += HardwareButtons_BackPressed; 
      view = CoreApplication.GetCurrentView(); 

     } 

     private void HardwareButtons_BackPressed(object sender, BackPressedEventArgs e) 
     { 
      if (Frame.CanGoBack) 
      { 
       e.Handled = true; 
       Frame.GoBack(); 
      } 
     } 

     protected override async void OnNavigatedTo(NavigationEventArgs e) 
     { 
      await StatusBar.GetForCurrentView().ShowAsync(); 
      Selected_ContactId = int.Parse(e.Parameter.ToString()); 
      currentcontact = Db_Helper.ReadContact(Selected_ContactId);//Read selected DB contact 
      namestxt.Text = currentcontact.Name;//get contact Name 
      relationtxt.Text = currentcontact.Relation;//get contact relation 
      phonetxt.Text = currentcontact.PhoneNumber;//get contact PhoneNumber 

     } 

     private void Update_click(object sender, RoutedEventArgs e) 
     { 
      currentcontact.Name = namestxt.Text; 
      currentcontact.Relation = relationtxt.Text; 
      currentcontact.PhoneNumber = phonetxt.Text; 
      Db_Helper.UpdateContact(currentcontact);//Update selected DB contact Id 
      Frame.Navigate(typeof(NextOfKin)); 
     } 

     private void Delete_click(object sender, RoutedEventArgs e) 
     { 
      Db_Helper.DeleteContact(Selected_ContactId);//Delete selected DB contact Id. 
      Frame.Navigate(typeof(NextOfKin)); 
     } 

     private void profile_img(object sender, TappedRoutedEventArgs e) 
     { 
      FileOpenPicker filePicker = new FileOpenPicker(); 
      filePicker.SuggestedStartLocation = PickerLocationId.PicturesLibrary; 
      filePicker.ViewMode = PickerViewMode.Thumbnail; 

      // Filter to include a sample subset of file types 
      filePicker.FileTypeFilter.Clear(); 
      filePicker.FileTypeFilter.Add(".bmp"); 
      filePicker.FileTypeFilter.Add(".png"); 
      filePicker.FileTypeFilter.Add(".jpeg"); 
      filePicker.FileTypeFilter.Add(".jpg"); 

      filePicker.PickSingleFileAndContinue(); 
      view.Activated += viewActivated; 
     } 

     private async void viewActivated(CoreApplicationView sender, IActivatedEventArgs args1) 
     { 
      FileOpenPickerContinuationEventArgs args = args1 as FileOpenPickerContinuationEventArgs; 

      if (args != null) 
      { 
       if (args.Files.Count == 0) return; 

       view.Activated -= viewActivated; 
       StorageFile storageFile = args.Files[0]; 
       var stream = await storageFile.OpenAsync(FileAccessMode.Read); 
       var bitmapImage = new BitmapImage(); 
       await bitmapImage.SetSourceAsync(stream); 

       var decoder = await Windows.Graphics.Imaging.BitmapDecoder.CreateAsync(stream); 
       profile.ImageSource = bitmapImage; 


      } 
     } 

    } 
+0

だけのsqliteデータベースに携帯電話のライブラリにあるイメージへのパスを保存するのではなく同じにしようとしていないのはなぜイメージ自体? – gattsbr

+0

はそれを試してくれます。ユーザーが電話から画像を削除しても影響を受けませんか? –

答えて

0

最良の方法は、画像をSQLiteに保存しないことです。 ApplicationData.Current.LocalFolderにコピーしてパスを保存してください。

あなたは本当にただのバイト配列に変換し、SQLiteの中でのBitmapImageを保存したい場合:Convert a bitmapimage to byte[] array for storage in sqlite database

関連する問題