<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0" xmlns:blogChannel="http://backend.userland.com/blogChannelModule" >
  <channel>
  <title>MCOS開発記録</title>
  <link>http://p98074.sugo-roku.com/</link>
  <atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="self" type="application/rss+xml" href="http://p98074.sugo-roku.com/RSS/" />
  <description>MCOS開発記録。
自分のための記録です。
別の人が見ても面白いところはないと思います。。。</description>
  <lastBuildDate>Fri, 05 Oct 2018 13:19:39 GMT</lastBuildDate>
  <language>ja</language>
  <copyright>© Ninja Tools Inc.</copyright>
  <atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="hub" href="http://pubsubhubbub.appspot.com/" />

    <item>
    <title>20181005 明日から3連休！</title>
    <description>
    <![CDATA[明日から3連休。<br />
進まない進捗を上げるいいタイミング。<br />
しかし、宣言しよう。<br />
明日からの3連休ではMCOSの開発はやらない！！<br />
ゲームをやる！！！<br />
と言っても、ゲームを作る方だけど。。。<br />
<br />
]]>
    </description>
    <category>未選択</category>
    <link>http://p98074.sugo-roku.com/%E6%9C%AA%E9%81%B8%E6%8A%9E/20181005%20%E6%98%8E%E6%97%A5%E3%81%8B%E3%82%893%E9%80%A3%E4%BC%91%EF%BC%81</link>
    <pubDate>Fri, 05 Oct 2018 13:19:39 GMT</pubDate>
    <guid isPermaLink="false">p98074.sugo-roku.com://entry/16</guid>
  </item>
    <item>
    <title>MCOS3デバッグ中03</title>
    <description>
    <![CDATA[<div>マウスフック処理でマウスの動作を検知する処理がない！</div>
<div>これは実装しなければ！</div>
<div>&hellip;&hellip;&hellip;&hellip;</div>
<div>問題にぶち当たった。</div>
<div>マウスカーソルの移動量を出すためには、マウスカーソルが移動しなければ検知できない。</div>
<div>しかし、マウスカーソルには移動制限がある。それは最大で画面サイズ。</div>
<div>だから、その制限を取っ払わないと、元画面よりも大きな画面には対応が出来ない。</div>
<div>いいか。とりあえず、この制限はある状態でリリースして、後で対応しよう。</div>
<div>&hellip;&hellip;&hellip;&hellip;</div>
<div>ダメだ。動いている途中のマウスの座標を更新しても、効かない。</div>
<div>おそらく、ソフト的にマウスの座標更新中にマウスが動作するため、ソフトのマウス座標更新が無視されるのだろう。</div>
<div>困った。</div>]]>
    </description>
    <category>未選択</category>
    <link>http://p98074.sugo-roku.com/%E6%9C%AA%E9%81%B8%E6%8A%9E/mcos3%E3%83%87%E3%83%90%E3%83%83%E3%82%B0%E4%B8%AD03</link>
    <pubDate>Sun, 30 Sep 2018 23:00:28 GMT</pubDate>
    <guid isPermaLink="false">p98074.sugo-roku.com://entry/15</guid>
  </item>
    <item>
    <title>MCOS3デバッグ中02</title>
    <description>
    <![CDATA[<div>考え方を大きく変える。</div>
<div>以前に考えていた話だが、すっかり忘れていた。</div>
<div>マウスの位置を制御するのは一度だけにする。</div>
<div>大きくマイナスの位置にする。</div>
<div>この変更は大きい。</div>
<div>&hellip;&hellip;&hellip;&hellip;</div>
<div>やってみたが、画面外に出す操作は効かなかった。</div>
<div>考え方を変えよう。</div>
<div>&hellip;&hellip;&hellip;&hellip;</div>
<div>マウスを消す、もしくは動かなくする。</div>
<div>マウスを消してもマウスのクリックは有効らしい。</div>
<div>マウスのクリックを無効にする方法を考えた！</div>
<div>そこにフォームを出せばいい。フォームでマウスのクリックイベントを拾わなければ、、、</div>
<div>よし。今日はこれでトライしてみよう。</div>]]>
    </description>
    <category>未選択</category>
    <link>http://p98074.sugo-roku.com/%E6%9C%AA%E9%81%B8%E6%8A%9E/mcos3%E3%83%87%E3%83%90%E3%83%83%E3%82%B0%E4%B8%AD02</link>
    <pubDate>Sat, 29 Sep 2018 23:27:56 GMT</pubDate>
    <guid isPermaLink="false">p98074.sugo-roku.com://entry/14</guid>
  </item>
    <item>
    <title>MCOS3デバッグ中01</title>
    <description>
    <![CDATA[<div>MCOS3ではMCOS2に制御が移っている間、MCOS3側のPCでは<br />
マウスを移動させない制御を行っているが、</div>
<div>そのはずだが、全く機能していない。何故だろう。</div>
<div>そう考えていたが、原因がわかった。</div>
<div>無駄に処理を行わないように動いていない場合はマウスの制御は行わないとしていたが、</div>
<div>そこにバグがあった。</div>
<div>&hellip;&hellip;簡単なようで簡単でないな。</div>
<div>MCOS3側のPCでマウスが動くのが嫌で、開始時の位置にマウスを動かすようにしているが、</div>
<div>ただクリックしただけでも、マウスの位置が違うから&hellip;&hellip;なぜ、マウスをクリックしただけで、</div>
<div>マウスの位置が違うんだ？　そこが問題では？</div>
<div>動作確認をして、原因の一つを見つけた。マウスの位置制御をしたら、</div>
<div>Control.MousePositionの値が変わった。Control.MousePositionの指す位置に移動させたのに。</div>]]>
    </description>
    <category>未選択</category>
    <link>http://p98074.sugo-roku.com/%E6%9C%AA%E9%81%B8%E6%8A%9E/mcos3%E3%83%87%E3%83%90%E3%83%83%E3%82%B0%E4%B8%AD01</link>
    <pubDate>Sat, 29 Sep 2018 09:25:31 GMT</pubDate>
    <guid isPermaLink="false">p98074.sugo-roku.com://entry/13</guid>
  </item>
    <item>
    <title>MCOS3の動作確認完了！？</title>
    <description>
    <![CDATA[<div>少し間が空いただけで何をやっていたのかすっかり忘れていた。</div>
<div>こういう時に記録があると便利。</div>
<div>少ししか時間がないけど、ESC*2で制御を戻す対応をいれよう。</div>
<div>&hellip;&hellip;動作を確認してみた。</div>
<div>ESC*2で制御が返る。先日対応してしまったのか？</div>
<div>そう思って、デバッグで動作を確認してみてわかった。</div>
<div>マウスの位置を制御する(実際にはまだ移動していない)&rarr;イベント発生&rarr;MCOS2に制御が移っていることを示すフラグが変わっているが、</div>
<div>マウスの位置が変わっていない&rarr;ということはMCOS2に制御を移さねば！！</div>
<div>という処理になっているため、デバッグ実行をすると、現象が再現している。</div>
<div>セマフォ的なやつを用意しよう。それで解決する見込み。</div>
<div>&hellip;&hellip;</div>
<div>ちょっと綺麗な対応ではないが、セマフォではなく、ワンタイムロックというような対応をしよう。</div>
<div>キーボードやマウスの移動で、マウスを制御する場合、直後のマウスフックイベントは無視する。</div>
<div>(自分で動かしたやつが通知されてくるのが分かっているので。)</div>
<div>&hellip;&hellip;</div>
<div>出来た！今日はこれで終わろうかしら？</div>
<div>今週末の課題を明確にしたいな。</div>
<div>いやいや、明確だわ。</div>
<div>動作確認を完了させる。MCOS3単独はとりあえず終わり。</div>
<div>次はMCOS2と接続する。その前にもう少し軽くしないといけない？</div>]]>
    </description>
    <category>未選択</category>
    <link>http://p98074.sugo-roku.com/%E6%9C%AA%E9%81%B8%E6%8A%9E/mcos3%E3%81%AE%E5%8B%95%E4%BD%9C%E7%A2%BA%E8%AA%8D%E5%AE%8C%E4%BA%86%EF%BC%81%EF%BC%9F</link>
    <pubDate>Thu, 27 Sep 2018 14:05:08 GMT</pubDate>
    <guid isPermaLink="false">p98074.sugo-roku.com://entry/12</guid>
  </item>
    <item>
    <title>酒の準備が出来るまでに</title>
    <description>
    <![CDATA[<div>酒の準備が出来るまでにもう少し時間があるので、課題の整理。</div>
<div>マウスの制御が出来てないので、マウスの制御を出来るようにする。</div>
<div>&hellip;&hellip;マウスの制御って必要ないんじゃ？</div>
<div>画面外に出してしまえば、元に戻そうとすればMCOS2から戻るようにしておけば。。。</div>
<div>画面外で右クリックして時にどんな動作になるのか？　CTRL+Aをしたら？</div>
<div>そこら辺を確認して問題なければ対処は結構簡単になる。</div>
<div>ならない可能性もあるけど。。。</div>
<div>やる価値はあるな。</div>]]>
    </description>
    <category>未選択</category>
    <link>http://p98074.sugo-roku.com/%E6%9C%AA%E9%81%B8%E6%8A%9E/%E9%85%92%E3%81%AE%E6%BA%96%E5%82%99%E3%81%8C%E5%87%BA%E6%9D%A5%E3%82%8B%E3%81%BE%E3%81%A7%E3%81%AB</link>
    <pubDate>Mon, 24 Sep 2018 06:38:36 GMT</pubDate>
    <guid isPermaLink="false">p98074.sugo-roku.com://entry/11</guid>
  </item>
    <item>
    <title>MCOS3実装完了ならず</title>
    <description>
    <![CDATA[<div>マウスの制御処理が大分重い。</div>
<div>でも、それだけじゃない。</div>
<div>&hellip;&hellip;色々いじって分かったことはUDP送信処理が原因だ。</div>
<div>UDP送信処理を切ったら凄く軽くなった。</div>
<div>もちろんMCOS3の最重要な処理のため、UDPを単純に消す訳にはいかない。</div>
<div>恐らくUDPクライアントの生成に時間を要していると思われるため、</div>
<div>UDPクライアントの生成は下記のいずれかのケースに絞ろう。</div>
<div>(1)起動時</div>
<div>(2)MCOS2との通信開始時</div>
<div>UDPクライアントのクローズ処理は上記ケースと逆。つまり、</div>
<div>(1)終了時</div>
<div>(2)MCOS2との通信終了時</div>
<div>で、もし、上記対応が許されないのであれば、スレッド上で常時UDPクライアントは使い続ける。</div>
<div>なので、キューに命令を保存して、UDP通信スレッドがそのキューの内容を読み取って、通信処理を行う。</div>
<div>&hellip;&hellip;</div>
<div>(1)の対応をしてみたが重い。</div>
<div>&hellip;&hellip;</div>
<div>newする処理をことごとく起動時に移すと、動作することがわかったが、同時にわかったことがある。</div>
<div>ESC&times;2で戻しても、マウスの座標が戻されてしまうため、無限に処理を抜けないということになりえる。</div>
<div>抜けた場合の処理を実装しよう。</div>
<div>&hellip;&hellip;</div>
<div>MCOS2に制御をうつした場合のマウスの座標をマイナスにしてしまおう。</div>
<div>そうすれば画面の外に出すことが出来る。</div>
<div>でも、これはもう少し先の話。MCOS2と通信を始めてからの話。</div>
<div>今日、MCOS2とMCOS3の接続まで行きたかったけど、ここまでか。。。酒飲もう。</div>]]>
    </description>
    <category>未選択</category>
    <link>http://p98074.sugo-roku.com/%E6%9C%AA%E9%81%B8%E6%8A%9E/mcos3%E5%AE%9F%E8%A3%85%E5%AE%8C%E4%BA%86%E3%81%AA%E3%82%89%E3%81%9A</link>
    <pubDate>Mon, 24 Sep 2018 06:34:41 GMT</pubDate>
    <guid isPermaLink="false">p98074.sugo-roku.com://entry/10</guid>
  </item>
    <item>
    <title>MCOS3が重すぎる</title>
    <description>
    <![CDATA[<div>MCOS3の動作が重すぎる。</div>
<div>テスト動作でまともに動作しない。</div>
<div>処理が重いところを解析しなければ&hellip;&hellip;</div>]]>
    </description>
    <category>未選択</category>
    <link>http://p98074.sugo-roku.com/%E6%9C%AA%E9%81%B8%E6%8A%9E/mcos3%E3%81%8C%E9%87%8D%E3%81%99%E3%81%8E%E3%82%8B</link>
    <pubDate>Mon, 24 Sep 2018 02:58:46 GMT</pubDate>
    <guid isPermaLink="false">p98074.sugo-roku.com://entry/9</guid>
  </item>
    <item>
    <title>とりあえずMCOS実装完了(UDP通信は未実装だけど。。。)</title>
    <description>
    <![CDATA[<div>UDPの受信処理は後でやるとして、それ以外は実装完了。</div>
<div>何故、UDPの受信処理を後でやるかというと、<br />
通信内容を確認してから実装した方が効率がいいから。</div>
<div>&hellip;&hellip;&hellip;&hellip;おぉ！　MCOSがとりあえず実装完了した！</div>
<div>という訳で、引き続きMCOSの動作確認！</div>
<div>明日中にMCOS2とMCOS3が繋がればいいなぁ。</div>]]>
    </description>
    <category>未選択</category>
    <link>http://p98074.sugo-roku.com/%E6%9C%AA%E9%81%B8%E6%8A%9E/%E3%81%A8%E3%82%8A%E3%81%82%E3%81%88%E3%81%9Amcos%E5%AE%9F%E8%A3%85%E5%AE%8C%E4%BA%86-udp%E9%80%9A%E4%BF%A1%E3%81%AF%E6%9C%AA%E5%AE%9F%E8%A3%85%E3%81%A0%E3%81%91%E3%81%A9%E3%80%82%E3%80%82%E3%80%82-</link>
    <pubDate>Sun, 23 Sep 2018 02:55:12 GMT</pubDate>
    <guid isPermaLink="false">p98074.sugo-roku.com://entry/8</guid>
  </item>
    <item>
    <title>少しだけ進んだ</title>
    <description>
    <![CDATA[<div>マウスのホイール制御も含めて対応完了。</div>
<div>進捗が悪い。ひとえにゲームをしているためだ。</div>
<div>ゲームをやめればもう少し作業時間を増やすことが出来るのだが&hellip;&hellip;</div>
<div>それはともかくとして、残りの作業は&hellip;&hellip;満載だ。</div>
<div>キーボードの監視も必要だし、UDPの受信処理も必要</div>
<div>&hellip;&hellip;思ってたよりも残作業が少ない。</div>
<div>ということはこの3連休で実装完了までいけそうだ。</div>]]>
    </description>
    <category>未選択</category>
    <link>http://p98074.sugo-roku.com/%E6%9C%AA%E9%81%B8%E6%8A%9E/%E5%B0%91%E3%81%97%E3%81%A0%E3%81%91%E9%80%B2%E3%82%93%E3%81%A0</link>
    <pubDate>Sat, 22 Sep 2018 08:38:21 GMT</pubDate>
    <guid isPermaLink="false">p98074.sugo-roku.com://entry/7</guid>
  </item>

    </channel>
</rss>