diff --git a/samples/Sample.WPF/MainWindow.xaml b/samples/Sample.WPF/MainWindow.xaml
index e4b8627..3682523 100644
--- a/samples/Sample.WPF/MainWindow.xaml
+++ b/samples/Sample.WPF/MainWindow.xaml
@@ -44,7 +44,10 @@
-
+
+
+
+
diff --git a/samples/Sample.WPF/MainWindow.xaml.cs b/samples/Sample.WPF/MainWindow.xaml.cs
index 16930c0..fcb59b5 100644
--- a/samples/Sample.WPF/MainWindow.xaml.cs
+++ b/samples/Sample.WPF/MainWindow.xaml.cs
@@ -34,10 +34,7 @@ namespace Sample.WPF
Messenger.Default.Register(this, m => m.HandleIt());
Messenger.Default.Register(this, m =>
{
- if (m.Sender == DataContext)
- {
m.HandleWithPlatform(this);
- }
});
Messenger.Default.Register(this, msg =>
{
@@ -78,6 +75,7 @@ namespace Sample.WPF
}
protected override void OnClosed(EventArgs e)
{
+ Messenger.Default.Unregister(this);
_twainVM.CloseDown();
base.OnClosed(e);
}
diff --git a/samples/Sample.WPF/ViewModels/CapVM.cs b/samples/Sample.WPF/ViewModels/CapVM.cs
index 833c396..3c83bc3 100644
--- a/samples/Sample.WPF/ViewModels/CapVM.cs
+++ b/samples/Sample.WPF/ViewModels/CapVM.cs
@@ -75,8 +75,6 @@ namespace Sample.WPF
}
}
- public object MyProperty { get; set; }
-
public CapabilityId Cap { get; private set; }
public string Name
@@ -85,7 +83,7 @@ namespace Sample.WPF
{
if (Cap > CapabilityId.CustomBase)
{
- return "[Custom] " + ((int)Cap - (int)CapabilityId.CustomBase);
+ return "[CustomBase]+" + ((int)Cap - (int)CapabilityId.CustomBase);
}
return Cap.ToString();
}
diff --git a/samples/Sample.WPF/ViewModels/DataSourceVM.cs b/samples/Sample.WPF/ViewModels/DataSourceVM.cs
index a2855ea..d9bced9 100644
--- a/samples/Sample.WPF/ViewModels/DataSourceVM.cs
+++ b/samples/Sample.WPF/ViewModels/DataSourceVM.cs
@@ -1,11 +1,19 @@
using GalaSoft.MvvmLight;
+using GalaSoft.MvvmLight.Command;
+using GalaSoft.MvvmLight.Messaging;
+using ModernWpf.Messages;
using NTwain;
using NTwain.Data;
+using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.ComponentModel;
+using System.Diagnostics;
+using System.IO;
using System.Linq;
+using System.Text;
using System.Windows.Data;
+using System.Windows.Input;
namespace Sample.WPF
{
@@ -69,5 +77,55 @@ namespace Sample.WPF
}
public ObservableCollection Caps { get; private set; }
+
+ private ICommand _saveCapCommand;
+
+ public ICommand SaveCapValuesCommand
+ {
+ get
+ {
+ return _saveCapCommand ?? (_saveCapCommand = new RelayCommand(() =>
+ {
+ Messenger.Default.Send(new ChooseFileMessage(files =>
+ {
+ StringBuilder report = new StringBuilder();
+ report.Append("Cap values for TWAIN device ").AppendLine(DS.Name);
+ report.Append("Generated on ").AppendLine(DateTime.Now.ToString("yyyy/MM/dd hh:mm tt")).AppendLine();
+
+ foreach (CapVM cap in _capView)
+ {
+ report.Append(cap.Name).AppendLine(":");
+ try
+ {
+ report.Append('\t').Append("Maybe: ").Append(cap.Supports).AppendLine();
+ report.Append('\t').Append("Get: ");
+ foreach (var v in cap.Get())
+ {
+ report.Append(v).Append(',');
+ }
+ report.AppendLine();
+ report.Append('\t').Append("Current: ").Append(cap.GetCurrent()).AppendLine();
+ }
+ catch (Exception ex)
+ {
+ report.Append('\t').Append("Failed: ").Append(ex.Message).AppendLine();
+ }
+ report.AppendLine();
+ }
+
+ File.WriteAllText(files.First(), report.ToString());
+
+ using (Process.Start(files.First())) { }
+ })
+ {
+ Caption = "Choose Save File",
+ Filters = "Text files|*.txt",
+ InitialFileName = DS.Name + " capability",
+ Purpose = FilePurpose.Save,
+ });
+ }, () => DS.IsOpen));
+ }
+ }
+
}
}
diff --git a/src/NTwain/CapWrapper.cs b/src/NTwain/CapWrapper.cs
index d8a9d44..ee4d0cd 100644
--- a/src/NTwain/CapWrapper.cs
+++ b/src/NTwain/CapWrapper.cs
@@ -1,6 +1,7 @@
using NTwain.Data;
using System;
using System.Collections.Generic;
+using System.Diagnostics;
using System.Linq;
using System.Text;
@@ -111,7 +112,9 @@ namespace NTwain
if (!_supports.HasValue && _source.IsOpen)
{
var srcVersion = _source.ProtocolVersion;
- if (srcVersion >= ProtocolVersions.GetMinimumVersion(Capability))
+ var minVer = ProtocolVersions.GetMinimumVersion(Capability);
+
+ if (srcVersion >= minVer)
{
_supports = _source.Capabilities.QuerySupport(Capability);
@@ -137,6 +140,7 @@ namespace NTwain
}
else
{
+ Debug.WriteLine("Cap " + Capability + " supports set to None due to rc=" + rc + ", cc=" + _source.GetStatus().ConditionCode);
_supports = QuerySupports.None;
}
}
@@ -144,6 +148,7 @@ namespace NTwain
}
else
{
+ Debug.WriteLine("Cap " + Capability + " supports set to None due to not in required TWAIN version (" + minVer + ") not met by source (" + srcVersion + ").");
_supports = QuerySupports.None;
}
}
diff --git a/src/NTwain/ICapWrapper.cs b/src/NTwain/ICapWrapper.cs
index d6bd1dc..6d69cb6 100644
--- a/src/NTwain/ICapWrapper.cs
+++ b/src/NTwain/ICapWrapper.cs
@@ -177,12 +177,13 @@ namespace NTwain
///
/// The value.
///
- ReturnCode SetValue(TValue value);///
- ///
- /// A version of Set that uses an array.
- ///
- /// The value.
- ///
+ ReturnCode SetValue(TValue value);
+
+ ///
+ /// A version of Set that uses an array.
+ ///
+ /// The value.
+ ///
ReturnCode SetValue(TWArray value);
///