WPF(.NET, WinUI) GUIプログラミング Part26

■ このスレッドは過去ログ倉庫に格納されています
2021/06/20(日) 17:04:18.66ID:7UVkl7BZ
Windows Presentation Frameworkについて語るスレ。

前スレ
WPF(.NET4.x, .NET Core) GUIプログラミング Part25
https://mevius.5ch.net/test/read.cgi/tech/1612522463

関連スレ
Windows 10 UWPアプリ開発 Part 2
http://mevius.2ch.net/test/read.cgi/tech/1499658092/

コードを貼る場合は以下のサイトの利用をお勧め。
run codeのチェックは外しておきましょう。
http://ideone.com/
2021/07/12(月) 20:28:01.38ID:Yv2DGcH3
>>528
MVVMアプリ的にはクライアント・サーバーのやり取りなんざまとめてMの範疇だろうに
そこの実装がプッシュだろうがポーリングだろうがどうでもいい話
2021/07/12(月) 20:32:07.25ID:EMnZux7N
まずPOCOが単なる入れ物って認識が間違い
2021/07/12(月) 20:34:47.17ID:P5SgcPEZ
POCOがあったらそこになんちゃらRepositoryやらなんちゃらServiceがあるわけじゃん
Modelはそれらを内包した概念なわけで
もうその辺から認識がズレてるから擦り合わせようがないんだと思う

話がどんどん後退していってる
2021/07/12(月) 20:36:41.56ID:LswkHmLx
なんでPOCOとDTOをゴッチャにしてんだ
WPFでMVVMやるならDTOはMの更に先にあるもんだぞ
そっかだからやたらポコポコ言ってんのか
申し訳ないがWebに例えないと話ができない人はNGに入れとくわ
2021/07/12(月) 20:39:06.39ID:P5SgcPEZ
MVVMのMには当然DTOが内包されるよね
更にその先って何?w
2021/07/12(月) 21:02:09.50ID:Gt7PpS3W
>>534
>実際は POCO は DTO と同義で用いられる事が多いかな。

そう思ってる人と正しく使ってる人とで話が噛み合ってない感じだよな。
2021/07/12(月) 21:30:46.04ID:EMnZux7N
>>540-541
これ、自演に失敗したのかな
2021/07/12(月) 22:04:12.08ID:0kBd/ns6
あのさ>>528は例えば特に>>495対するレスで、単にUIとは関係ない一般的な
通知論を言っただけで、>>541の言いたい事を否定してるように見えないんだけど
むしろ君の味方だと思うんだが、>>541は全員敵に見えてるの??
2021/07/12(月) 22:19:19.66ID:0kBd/ns6
ああ、ごめん俺が間違ってたww
>通知処理(Modelの購読が必要になるケース)なんてほぼほぼ無くて
ここでちゃんと否定してたねw
2021/07/12(月) 22:20:11.65ID:LswkHmLx
>>555
エコシステムの話をしてるんじゃなくてWPFアプリの話をしてるので
MVVMのMをWPFアプリでどう実装するかが論点なのよ
2021/07/12(月) 22:22:33.14ID:e9fWYKI2
一応はWPFなりMVVMなりを前提として話してるもんだと思ったらまさかのUIは関係ない宣言

U I は 関 係 な か っ た !

そら誰とも話通じんわw バカ同士仲良くしてくれ
2021/07/12(月) 22:25:45.89ID:0kBd/ns6
いや、やっぱ>>556取り消すわ
やっぱ、>>528は単に>>495に対するレスにしか見えないな

>>557
論点はそこにあると思うけど>>528は通知の一般論話しただけかもしれん
2021/07/12(月) 23:41:05.62ID:B/Smfxyl
なんじゃこりゃ!
561デフォルトの名無しさん
垢版 |
2021/07/12(月) 23:46:26.66ID:B/Smfxyl
WPFに限らず一般的な話してるだけじゃん
2021/07/12(月) 23:57:26.60ID:0kBd/ns6
俺は土曜日までは会話に主な論点わかってたけど

昼間に君のレス見て、UIと通知を結びつける人がいて気になってたから、その人向けにUI関係ない通知の一般論言ってるんだろうと納得してたら

夜みて、通知の一般論言ってるだけなら全く関係ない人が怒り出してから草
って感じ
2021/07/13(火) 00:56:18.26ID:xjJDoKS2
だってWPFと関係ない話になってんだもん
むしろ論点ずらししてるっしょ
2021/07/13(火) 05:46:23.04ID:fhfe26+M
頭ひろゆきかよ
2021/07/13(火) 08:46:15.95ID:Pw5n0ID3
VMに相当する部分にビジネスロジックをガッツリ書くのはアプリ設計としてありだが、それはMVVMじゃないな
MVVMはModelにビジネスロジックを書くのが本来の定義だ
2021/07/13(火) 08:51:29.18ID:+zVQ74um
いやあ皆性格わるいねえw
醜いもんだよw
2021/07/13(火) 09:07:04.94ID:xejzJ7TX
>>547は最悪の性格だと思うww
>>528に勘違いでぶきちれてる
2021/07/13(火) 09:08:01.98ID:xejzJ7TX
ぶちきれてるねw
2021/07/13(火) 09:18:27.78ID:DZCKnpMT
>>565
そんな設計はもうViewModelなんて言葉を使うべきじゃねえわ
MVCでもMVVMでもないどころか関心の分離すら無視した全く別の何かじゃん
2021/07/13(火) 09:23:04.37ID:DZCKnpMT
どんなプログラミングパラダイムを採用しようと
UIの変更にモデルは影響されないのが原則だと思ってる

例えばWPFで作ったものをASP.netでWebインターフェイスに変更することになったとしてもモデルには一切触れなくて済むのが本来あるべき姿
しかしモデルにUIのための通知機能を入れた途端にそれは破綻する
別にモデル通知機能があったって動くから良いだろと言う話ではない

そこがモデルに通知機能を実装する違和感の根源
571デフォルトの名無しさん
垢版 |
2021/07/13(火) 10:32:02.27ID:2EC2vCMH
変更を通知するサービス

たとえばみんなが知ってる gmail(いわゆるPushメール)とかは
クライアントを WPF でも Flutter でも React でも作れると思いますが、
ではこの機能は何に相当するのでしょうか?
572デフォルトの名無しさん
垢版 |
2021/07/13(火) 10:53:55.72ID:s3qWh6Np
通知機能のあるMをVMのObservableCollectionでVに公開すると
このMはVMになりますか?
MVVMでは反則でしょうか?
2021/07/13(火) 10:55:02.74ID:t7skZb6/
>>571
何とは?
MVVMの役割のことを言っているのあれば、どれでもない
Mの中で使用される機能と言うだけ
2021/07/13(火) 11:08:48.39ID:dtNqNBdW
Amazon SNS(Simple Notification Service)は、

そのためだけにサーバーを用意しなくても、
アプリケーションからの通知を可能にするサービスです

ユーザーが何かを行ったタイミングで通知する
「イベントドリブン」なメッセージングを手軽に実現します
2021/07/13(火) 20:50:38.25ID:b1BrGGh1
>>570
>しかしモデルにUIのための通知機能を入れた途端にそれは破綻する

そこに依存性逆転パターンを使うのが常套手段。
2021/07/13(火) 22:05:10.54ID:xjJDoKS2
>>572
Collectionの要素に変更があるのを監視する必要がなければそれでOK
別に反則じゃないと思う
2021/07/14(水) 19:37:54.90ID:Ftj7Gfdw
今日は勝ちたい病のVMにビジネスロジック実装する君は来てないの?
2021/07/14(水) 21:01:12.91ID:FWHo5b9L
どうした、恋しいか?
2021/07/14(水) 22:40:50.82ID:UYQRt03E
こないと>>547の馬鹿みたく関係ない人攻撃しだすからなww
2021/07/14(水) 22:48:26.38ID:Ftj7Gfdw
え?
ID:B/Smfxylは馬鹿だよ
2021/07/14(水) 23:03:29.16ID:UYQRt03E
久しぶりにみたわ
必死過ぎて全員敵に見える病ww
2021/07/14(水) 23:13:04.52ID:wjhDeS6u
家に鏡がないのか?
鏡を買えば毎日見られるぞ
2021/07/15(木) 02:12:58.55ID:rXkSqNZ0
自分がそれで見られるからって
他人が同じことして見られると思ってるあたりが馬鹿だよね
2021/07/15(木) 08:43:28.31ID:erbvpp8v
みんな皮肉が上手だなあ(鼻ホジ)
585デフォルトの名無しさん
垢版 |
2021/07/15(木) 10:10:56.93ID:Gu3XCrlD
>>576
いやMの通知をVが監視する状態だよ
586デフォルトの名無しさん
垢版 |
2021/07/15(木) 14:23:21.77ID:VeQWWe0f
ロジックはコマンドに書いてるけどコマンドってVMの仲間じゃないの?
2021/07/15(木) 19:55:28.67ID:yhXjFIIz
>>585
原理主義通すならその通りなので止めた方が良い
大規模プロジェクトで規約作る段階とかならあなたの言う通り
そうでないなら工数とのバーター
2021/07/15(木) 20:40:50.25ID:yPgIH8DR
そういやコレクションでもしっかりVM挟めって人がWPF出来て直ぐの頃は言う人いたよな
2021/07/15(木) 23:20:18.67ID:twFSqmod
なんか人によってVMの定義が違うのかねぇ?
WPFだとDataContextにセットするのがVMだと認識しているが。
2021/07/15(木) 23:31:38.36ID:yPgIH8DR
>>589
ListViewなどでも、内部的にListViewItemのDataContextにコレクションのアイテムがセットされるから何も変わらないよ
それにVM挟めというやつが昔はわりといた
2021/07/16(金) 19:02:18.73ID:tbXedaSH
ビジネスが破綻する大半の原因は、 ”ビジネスを始める人の大半が、真の意味での
「起業家」ではなく、 起業したい、という熱に浮かれた「職人」として働いているに過ぎない。”
という事実にあります。
「職人」によって運営されているビジネスは、ビジネスが働くのではなく、彼ら自身が毎日働くこと
によって、成り立っています。
彼らは毎日、自分がやり方を知っている仕事を一生懸命にこなしていますが、「起業家」としての
視点が無いために、成長に限界が生まれます。
そして、生計を立てるために、彼ら自身がずっと働き続けないとならないのです。

誰もが必ず陥る罠
私が見ている限り、起業熱にうなされる人たちは、必ずと言ってもよいほど誤った
「仮定」を置いてしまうようだ。実は、のちに彼らが苦難の道を歩むことになるのは、
この、「仮定」が致命的に間違っているからなのである
致命的な仮定とは・・・「事業の中心となる専門的な能力があれば、事業を経営する能力は
十分に備わっている」ということである
私がこの仮定を致命的だと書いたのは、この仮定が間違っているからにほかならない
事業の中で専門的な仕事をこなすことと、その能力を生かして事業を経営することは
全く別の問題である。高い専門能力を持つ人にとって、独立は他人の為に働くという苦痛から
解放されるということを意味していた。それにもかかわらず、前提となる「仮定」が致命的とも
いえるほど間違えているために、彼らは自由になるどころか、自分が始めた事業に苦しめ
られるようになってしまうのである
マイケルEガーバー「はじめの一歩を踏み出そう」P28~29
2021/07/16(金) 20:45:27.50ID:nOgfrdpb
>>590
それは問題なくて、逆にDataContextと関係ないものまでVMと言っている人がいるような気がしたんで。
2021/07/21(水) 18:44:02.13ID:za3x9XY8
年末まで動きはなしか
2021/07/21(水) 21:28:05.11ID:0TrBhSUB
>>593
それでも0.5と違ってreunion0.8は、そこそこ安定しているよ
2021/07/22(木) 05:38:57.11ID:fbsqHODV
なんでtextblockってこんな中途半端に作ってあるのかな
作ってるときに上下のスペース気にならなかったのか
2021/07/22(木) 17:25:19.02ID:lRm6lFPm
なんのこと?
2021/07/22(木) 18:31:15.26ID:vwDpdZeF
richtextboxの上下のスペースなら気になった
馬鹿が作ったんだろうなとニヤニヤした
2021/07/22(木) 20:01:46.34ID:PV0Y3pfC
全角半角混在バカ
2021/07/23(金) 06:59:12.37ID:F886/8HL
WinUI早くソース公開してくれ
2021/07/23(金) 12:50:01.83ID:YjvHno2g
そーっすね
2021/07/23(金) 19:10:22.48ID:LsYzUOc/
そこでWPF完全終了?
2021/07/24(土) 15:09:24.06ID:B0+KuVSr
>>601
1.0が出てから触ってみるつもりだから分からん。
UWPが見向きもされなかった欠点が解消されてるなら移行するし、
駄目ならWPFとWinUIのミックスになるかもしれない。
2021/07/24(土) 17:27:17.07ID:XrMlrlks
WinUIってWPFよりUWPのほうが近くない?
2021/07/24(土) 18:17:14.05ID:jHuzu2oV
基本的にGUIはUWPが基本でほんの一部異なる程度
売りはファイルアクセスなどの制限のない.netのクラスや
C言語のライブラリが普通に使えること

残念なのは.net nativeは対応していないからUWPほど高速にはならないところだな
2021/07/24(土) 19:31:02.40ID:m9/tzZBE
これがreunionちゃんか?
ttps://docs.microsoft.com/ja-jp/windows/apps/desktop/modernize/xaml-islands
ttps://docs.microsoft.com/ja-jp/windows/apps/desktop/modernize/host-standard-control-with-xaml-islands
2021/07/24(土) 20:52:35.53ID:PoLbY2rq
俺はカラー絵文字が普通に使えさえすればもうWPFで十分なんだけど
それってUWPのコントロールが使えるようになるとかいうnugetパッケージ入れりゃ簡単にできるもんなの?
2021/07/25(日) 12:45:55.14ID:KYDDSoJA
備品管理のために配置図作成プログラムを作るために下の二つを使いたい

マップ描画用
https://noitalog.tokyo/wpf-excel-shape/

UndoRedo機能用
https://qiita.com/nossey/items/c59910558d5501f03ad0


Undo機能でマップ描画のキャンセルをしたいんだけど
Record(() => { /*do*/ }, () => { /*undo*/ });のところに何を入れればいいのか分からない
何を入れれば実現するのか教えてください

もしくはもっといいライブラリがあれば教えてください
2021/07/25(日) 15:14:28.53ID:NdwY3sWp
>>607
そういうツール作ったことあるけど、Undo/Redoは状態そのものを記録する方式の方が楽だよ
操作ごとに描画したモデルをスタックに積む感じでとっておいて
Undoでポインタを遡る、Redoされたらポインタを進める
2021/07/25(日) 15:39:24.67ID:KYDDSoJA
つまり別のライブラリを使った方がいいってことですね
探してみます
2021/07/25(日) 15:50:45.11ID:UpcvNBvN
>>609
608が言ってるのはstateをスタックに積むだけなので、Stack<T>を使えばライブラリは不要。
考えるべきはstateを表現する方法かと。
2021/07/26(月) 13:34:11.89ID:if+3GvI0
undo/redoをcommandパターンで実現するときのネックは、逆方向への操作を綺麗に実装出来るかどうか
たとえば、0から1増やす操作は可逆性があるので簡単だが、0を1に変更する操作は可逆性がないので元の値を必要な分だけcommandに設定しておかないといけない
必要な分が広範囲になると、丸ごと状態を記録するのと変わらなくなってしまい、ただ実装が複雑になる
stateパターンの場合は、実装が簡単というメリットの代わりに、状態をうまく独立させないとリソースを大量に消費するというデメリットがある
commandパターンで、直接状態を変更するcommandを作るのではなく、状態の差分を算出して適用できるように実装出来れば、両者の問題を解決できる
612デフォルトの名無しさん
垢版 |
2021/07/26(月) 15:01:38.67ID:sA+3cpxO
doに新しい状態でundoに古い状態を入れたらいいんでしょ
規模も不明なんで丸ごと記録でいいんじゃない
613デフォルトの名無しさん
垢版 |
2021/07/26(月) 18:39:34.76ID:HAWagkhF
Undo可能クラスも実装出来んの?
(例)
var val1 = new Undoable<int>(0);
val1.Set(1);
val1.Undo();
val1.Commit();
if (val1.Value == 0) {
}
614デフォルトの名無しさん
垢版 |
2021/07/26(月) 18:41:04.91ID:HAWagkhF
UndoableクラスのValueプロパティーをInotifyPropertyChangedで実装しとけ!
2021/07/26(月) 21:06:01.64ID:if+3GvI0
>>613
これ足し算するときは
val1.Set(val2.Value+val3.Value)
って書かせるのか?
616デフォルトの名無しさん
垢版 |
2021/07/26(月) 22:19:37.90ID:HAWagkhF
getter位実装しろや
617デフォルトの名無しさん
垢版 |
2021/07/26(月) 22:28:38.74ID:HAWagkhF
setter ...(; ・`д・´)!
618デフォルトの名無しさん
垢版 |
2021/07/26(月) 22:34:21.59ID:rgsHaqle
>>613
その実装をどうしようって話だと思うんだけど
2021/07/26(月) 22:40:13.03ID:HAWagkhF
どこまでおんぶにダッコよ(>_<。)!
2021/07/26(月) 22:46:07.45ID:FJAlPqYb
編集するタイプごとのenum作って復旧/削除用のバッファ・位置情報を持つクラスを作るのだ
通常の編集処理に渡せるようにできるかがあんきも
2021/07/26(月) 23:08:38.92ID:rgsHaqle
>>619
元の質問読んでなさすぎだろw
622デフォルトの名無しさん
垢版 |
2021/07/26(月) 23:14:37.82ID:HAWagkhF
ゴミと判断した
2021/07/27(火) 13:29:46.95ID:/oZqPjm8
>>607ですがC#ほとんど素人です
stack<t> にcanvasを入れてみてpushやpopしても上手く変更されず
2021/07/27(火) 18:46:15.06ID:KMLdgMbQ
>>623
参照型が理解できてないっぽい。
残念だが初心者スレでは無いのでここまで。
625デフォルトの名無しさん
垢版 |
2021/07/28(水) 09:34:26.66ID:m3dX+aIk
>>623
確かどっかにC#初心者スレがあったはずだから
2021/07/29(木) 12:37:19.54ID:VxNcNDZg
こっちクローズして初心者スレ行きます
2021/08/01(日) 18:11:43.70ID:tzaLBmjr
c#に慣れてきてWPFに挑戦しようかなと公式チュートリアルのHello Goodbyeを試した。
1.まずはxamlの名前を変えましょうでエラー。
1時間ほどなら悩みまくってチュートリアルページ遥か下にデバッグの項目で意図的なバグだとわかった時はキレそうになった。
引き続き学習しようと思ってるんだけど、参考になるサイトある?
2021/08/01(日) 18:45:22.56ID:BCtBnKvQ
かずき
2021/08/01(日) 20:21:17.09ID:ovUX7fTa
xamlはhtmlと同じようにタグをエディターで入力するしかないって気づいたところから使えるようになっていったな
Formsみたくコントロールをマウスで並べようとして挫折しかけた
630デフォルトの名無しさん
垢版 |
2021/08/01(日) 21:11:07.02ID:zuqV0aN+
タグ書いて完璧なUIを作るのが楽しい
グラフィカルなエディターってチラ見するだけのものだな
2021/08/01(日) 21:17:10.83ID:zRRMy60W
公式チュートリアルにHello Goodbye(world?) なんてあったっけ
2021/08/01(日) 22:31:27.62ID:tzaLBmjr
>>631
チュートリアル: C# で単純なアプリケーションを作成する 2021/02/10
ttps://docs.microsoft.com/ja-jp/visualstudio/get-started/csharp/tutorial-wpf?view=vs-2019

Hello Worldレベルでつまづいたのは初めてでショック。
wpf tutorialで検索したら良さげなサイト見つけられたからもういいんだけどね。
2021/08/01(日) 22:31:58.77ID:hLrbx4IS
ハロー!そしてグッドバイ!
2021/08/02(月) 01:14:13.50ID:GLNJH6H3
>>632
StartupUriを変更してないから実行時エラーになる件?
チュートリアルを手順通りやってれば悩むようなことなくね?
2021/08/02(月) 12:27:13.51ID:cBPUjued
>>629
Formsと同じような作り方してると結局Formsと同じくサイズ変更やレイアウト変更に脆い画面になっちまうんだよな。
GUIから貼り付けると余計なプロパティも追加されてごちゃつくし。
XAML用のコードスニペット用意して爆速コーディングがお勧め。
636デフォルトの名無しさん
垢版 |
2021/08/02(月) 17:35:01.31ID:OwNzYS4q
縦にズラーと並べてご満悦ですか
2021/08/03(火) 06:02:09.33ID:YKUXzg3a
WrapPanelもあるでよ
2021/08/05(木) 12:08:27.09ID:LnW659PN
winui触ってるけど非同期メソッド多すぎてイライラする
慣れたら気にならなくなるのかな
2021/08/05(木) 12:48:41.25ID:qCKYnrg6
むしろ非同期メソッドが用意されていない方がイライラするだろ。
640デフォルトの名無しさん
垢版 |
2021/08/05(木) 21:46:17.56ID:iyi+GUtj
>>638
WinUIまだ触れてなくて分からないんだが、もうDispatcher.Invokeしなくて良くなるの?
2021/08/05(木) 22:11:14.99ID:hAnk8QxE
きっちりMVVMしてりゃDispatcher.Invokeなんて出番ないんだが。
2021/08/05(木) 22:41:02.46ID:szLnk8N0
>>640
https://docs.microsoft.com/en-us/dotnet/api/microsoft.toolkit.uwp.DispatcherQueueExtensions?view=win-comm-toolkit-dotnet-7.0

こんなクラス使ってUIスレッド呼び出すんだわ
2021/08/06(金) 00:49:06.65ID:y474vaxZ
最近のアプリはクリックしたあとすぐに反応しないアプリ多すぎ。というかWindows10。

馬鹿に非同期の実装は無理ということ。
2021/08/06(金) 18:59:51.04ID:gqafcbP7
OneNote UWP版、死亡。
着実に脱UWPしていってるな、よしよし。
2021/08/08(日) 10:59:54.62ID:CLpDwXEd
コード簡略のためにawait 使いまくってるサンプルが世に広まってるのが良くないのかね(´・ω・`)
2021/08/10(火) 10:09:01.90ID:l4gp57RE
MahAppsでGUI作っていたけど今更Metro(Modern) UIというのもアレなんで
最近出たらしいWinUI 3.0で組もうとしているけど、ウィンドウサイズを変えることができない。

なんか、いい方法ない?

あと、WPFで使っているからかもしれないが、Windows.Storage.FilePickerの動作がなんか不安定だ。
PickSingleFileAsyncは動くのにPickMultipleFilesAsyncだとコケる。
2021/08/10(火) 10:50:56.88ID:WgvQ9Z8W
>>646
User32でハンドル拾ってメソッドを呼び出すと色々出来ます
いろいろ調べたけど、現状だとこうするしかない模様
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況