CommandManager.InvalidateRequerySuggested();
を実行して、RequerySuggestedイベントを強制的に発生させてCanExecuteが実行されるようにできる。
UIスレッドと別スレッドから呼び出すときはDispatcher.Invoke()やDispatcher.BeginInvokeのデリゲートから呼び出す。
CommandManager.InvalidateRequerySuggested();
を実行して、RequerySuggestedイベントを強制的に発生させてCanExecuteが実行されるようにできる。
UIスレッドと別スレッドから呼び出すときはDispatcher.Invoke()やDispatcher.BeginInvokeのデリゲートから呼び出す。
WebRequestの最大同時接続数を変更するにはでプログラムから変更する方法をメモしたが、設定ファイルでも変更する方法は以下。
app.configに下記の設定を追加する。
<system.net>
<connectionManagement>
<add address=”*” maxconnection=”20″/>
</connectionManagement>
</system.net>
WebRequest クラスの最大同時接続数のデフォルト値は2のため、
複数のサイトに動じアクセスする場合は変更する必要がある。
変更するには
System.Net.ServicePointManager.DefaultConnectionLimit
プロパティに設定を行えばよい。
下記のように外部スクリプトとして追加することで実行できるようになった。
var webBrowser = new WebBrowser();
HtmlElement scriptElem= webBrowser.Document.CreateElement(“Script”);
scriptElem.SetAttribute(“type”, “text/javascript”);
scriptElem.SetAttribute(“src”, http://localhost/script.js);
<Script>タグ内へinnerHtml, innerTextを使ってコードを追加できなかった。また、srcの参照先を”file:///“で始まるものにすると、実行時にエラーとなる。javascriptの関数を実行するには
object obj = webBrowser.Document.InvokeScript(“functionname”);
と記述する。第2パラメータにobjectの配列を渡すことで引数を指定することが可能。
.Net FrameworkにはUriエンコードに使うメソッドがいくつかあるが、違いを調べてみた。
Uriクラスのメソッドは、国際化リソース識別子 (IRI) または国際化ドメイン名 (IDN) 解析を有効に設定するとRFC3986準拠になるようだが、システム全体が変わってしまうようなので、個別にやるにはRFC3986で増える予約記号「!’*()」を後から置換するのが現実的かも。
WPFでWindows FormのApplication.DoEventsメソッドと同様に長時間かかる処理の間にUIのイベントを処理させるには、下記のように行う。(MSDNより)
[SecurityPermissionAttribute(SecurityAction.Demand, Flags = SecurityPermissionFlag.UnmanagedCode)]
public void DoEvents()
{
DispatcherFrame frame = new DispatcherFrame();
Dispatcher.CurrentDispatcher.BeginInvoke(DispatcherPriority.Background,
new DispatcherOperationCallback(ExitFrame), frame);
Dispatcher.PushFrame(frame);
}public object ExitFrame(object f)
{
((DispatcherFrame)f).Continue = false;return null;
}
Xml-Rpc With WCFから「XML-RPC for WCF」をダウンロード。
上記blogのコメントに従ってXmlRpcDataContractSerializationHelperクラスのDeserializeStructメソッドのループ
while (reader.NodeType != XmlNodeType.EndElement)
{
}
の最後に、下記を追加。(ホワイトスペースと改行(XmlNodeType.Text)をスキップするため)
while (reader.NodeType == XmlNodeType.Whitespace || reader.NodeType == XmlNodeType.Text)
{
reader.Skip();
}
また、Desirializeメソッドでswitch (reader.LocalName)の case XmlRpcProtocol.DateTime:の日付の形式が、dateTime.iso8601の形式(下記例参照)でなかったため修正。
<dateTime.iso8601>19980717T14:08:55</dateTime.iso8601>
また、Desirializeメソッドで<value>の内側に型のタグがない場合stringにする処理がなかったため、メソッドの一番最後に
else if (reader.NodeType == XmlNodeType.Text)
{
returnValue = reader.ReadString();
}
を追加した。このモジュールの使う手順は下記。
<system.serviceModel>
<extensions>
<behaviorExtensions>
<add name=”xmlRpcEndpointBehavior”
type=”Microsoft.Samples.XmlRpc.XmlRpcEndpointBehaviorSection, Microsoft.Samples.XmlRpc, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null” />
</behaviorExtensions>
</extensions>
<services>
<service behaviorConfiguration=”debugBehavior” name=”実装したクラス名”>
<host>
</host>
<endpoint address=”" behaviorConfiguration=”xmlRpcBehavior” binding=”webHttpBinding”
contract=”定義したインタフェース名” />
</service>
</services>
<behaviors>
<endpointBehaviors>
<behavior name=”xmlRpcBehavior”>
<xmlRpcEndpointBehavior />
</behavior>
</endpointBehaviors>
<serviceBehaviors>
<behavior name=”debugBehavior”>
<serviceMetadata httpGetEnabled=”true” />
<serviceDebug includeExceptionDetailInFaults=”true” />
</behavior>
</serviceBehaviors>
</behaviors>
<serviceHostingEnvironment multipleSiteBindingsEnabled=”true” />
</system.serviceModel>