■MFC相談室 mfc17d.dll■ at TECH
[2ch|▼Menu]
[1からを表示]
50:デフォルトの名無しさん
06/11/27 22:15:40
ダイアログベースのアプリで、Client領域に背景ビットマップを貼り付けています。
このダイアログの上で他のウィンドウをぐりぐり動かすとダイアログが再描画された時に
背景が部分的に欠けてしまう(ダイアログの地の色が出る)事があるんですが、
これってどんな理由が考えられるでしょうか。

51:50
06/11/27 22:27:39
WinXP+VC6.0です

52:デフォルトの名無しさん
06/11/27 22:40:32
VC6 MDI に MDI タブ機能を追加するにはどうしたらいいですか?

53:デフォルトの名無しさん
06/11/27 23:30:57
そういう機能は存在しない

54:デフォルトの名無しさん
06/11/28 00:13:23
>>48
標準的なCViewのサブクラスは印刷時に
CView::OnFilePrint();を呼び出している。
ただしCListViewから呼び出しても印刷できるかどうか
わからん。

55:デフォルトの名無しさん
06/11/28 19:46:02
>>49
試した。確かにサイズ変更できない。
原因は非公開クラスのCDockContext内のStretch()にあって
dockcont.cppの314-315行目のサイズ取得のところ。
最新のMFCではこっそりと修正されてる。
(VC6SP6)
HWND hWndDesk = ::GetDesktopWindow();
::GetWindowRect(hWndDesk, &rectDesk);
(VC2005)
rectDesk.left=GetSystemMetrics(SM_XVIRTUALSCREEN);
rectDesk.top=GetSystemMetrics(SM_YVIRTUALSCREEN);
rectDesk.right=rectDesk.left+GetSystemMetrics(SM_CXVIRTUALSCREEN);
rectDesk.bottom=rectDesk.top+GetSystemMetrics(SM_CYVIRTUALSCREEN);

VC6ではCToolBarとCDockContextを派生させて対処するしかない(当方では一応成功)。
非公開クラスなのでググってもほとんど情報がないけど
修正内容は違うがCDockContextを弄ってるのはあった。
URLリンク(www.ddj.com) 英語だがStep3,Step4の文章が多少参考になる。
URLリンク(www.tkb-soft.hmcbest.com) 日本語。最後の方がグダグダでかなり強引。

56:デフォルトの名無しさん
06/11/29 01:44:19
質問です。
フォルダやファイルのフルコントロール拒否ってどうやってみたらいいでしょうか?
今はとりあえず、書きこんで見て書けなかったら・・・とかやっています。
もっとスマートな方法はないでしょうか?

57:デフォルトの名無しさん
06/11/29 06:17:19
質問なんですけど。

IEの履歴ウィンドウみたいなのあるじゃないですか?
あのスプリッタに「X 閉じるボタン」が付いてるやつ。
あれってMFCの機能で実現出来るものですかね?

スプリッタウィンドウにして一つのViewをFormViewにして
その中に各種のコントロールを設置すればそれっぽくなりますけど
閉じるボタンが押された時に、スプリッタを完全に非表示にしないといけない訳で
スプリッタの大きさ0じゃなく、動的にスプリッタの数を変更とか出来るのでしょうか?

58:デフォルトの名無しさん
06/11/29 08:58:38
>IEの履歴ウィンドウみたいなのあるじゃないですか?

あれはBrowser Extension の Explorer Bar
URLリンク(msdn2.microsoft.com)

>あれってMFCの機能で実現出来るものですかね?

本人次第

59:デフォルトの名無しさん
06/11/29 09:49:59
CSplitterWnd内部では当然ペインの数は管理しているので
サブクラスで操作(数だけじゃないよ)すればできる。
流れ書こうかと思ったけどCodeGuruとか見たほうが早い。

ペインが左右に1つずつしかないなら、ほんの数行で済むはず。

60:デフォルトの名無しさん
06/11/29 10:31:28
>>58
なるほど… そういう物だったんですね…

>>59
今、色々試していた所、CDialogBarを利用して
似たような事が出来るかも知れないと思いました。
出来ればVC++のIDEみたく、ドッキング可能にもしたかったので
こっちの方がより理想に近いのかもしれません。

61:49
06/11/29 20:45:04
>>55
試していただきありがとうございます。
やっぱりこれグラフィックカードの問題とかではなかったんですか…。

ツールバーももちろんなんですが、
URLリンク(support.microsoft.com)
↑を参考にサイズ変更可能なダイアログバーを用意したんですけど、
セカンダリモニタ上でサイズ変更ができないのがかなり痛いです。

これって、VC6のままMFCだけ最新のものを使うということは無理で、
VC2005の環境にしてしまうか、派生クラスを自分で作ることになるんですよね?
ドッキングを捨ててモードレスダイアログにしてしまったほうがいいのかな…。

まずは教えていただいたサイトなどを元にして
なんとか挑戦してみたいと思います。
ありがとうございました。

62:デフォルトの名無しさん
06/11/29 22:26:25
ウィンドウやダイアログ(以下、あわせて子画面と記述)を追加するMFC拡張のDLLを作成しています
仕組みそのものは簡単で、アプリケーションからグローバル関数を通じて呼び出されます
グローバル関数は子画面ごとに用意し、関数の引数にポインタを指定する形でデータの受け渡しを行います

それで早速これを作り始めたのですが、自分の知識が乏しいこともあって問題が発生してしまいました
それは、ウィンドウを上手く表示させて処理させることができないということです
ダイアログの方はモーダル表示であるためか、特に問題なく表示させて処理させることができました
しかし、ウィンドウの方は違いました
新規クラス作成でCFormViewを継承したクラスを追加しているのですが、生成の段階で問題が発生してしまいます
コンストラクタがprotectedとなっているため、newで生成したときにエラーとなるのです
これは手動でpublicに変えることで表面上は解決しました
しかし、標準でprotectedになっていたことには何か意味があるのではないかと不安に思えてきました
大丈夫なのでしょうか?

また他にも問題があります
それは、メモリの開放です
ウィンドウはモーダルではないため、基本的にグローバル変数として使っています
これが問題となるのはユーザが閉じるボタンでウィンドウをデストロイした場合です
グローバス関数では、対応するウィンドウのグローバル変数がNULLでない場合に明示的にDestroyWindowを呼んでいます
その後にdeleteをしております
しかし、ユーザがすでにウィンドウをデストロイしていた場合、エラーが発生します
これをどうにか防ぎたいのです
ウィンドウがすでにデストロイされていることを知る手段はありませんか?
またはメモリが未開放であることを知る手段はありませんか?

とても困っております
知恵を貸してください

63:デフォルトの名無しさん
06/11/29 23:18:34
>>62
Viewの作成は通常newは使わず
CView *MyView = (CView *)RUNTIME_CLASS(CMyView)->CreateObject();
context設定して MyView->Create( ・・・ );
とかいう感じ。

後半はframeを保持しているのがどっちか不明なのでパス。

64:62
06/11/30 00:09:29
>>63
レスに大感謝です
参考にさせて頂きます

グローバル変数を保持しているのはDLLです
つまり、ウィンドウ&ダイアログは常にDLLの管理下にあります
アプリケーションは子画面の表示を指示するのとデータ受け渡しのみです

65:デフォルトの名無しさん
06/11/30 00:50:10
MDIのドッキングウィンドウってどうやればできますか?

66:デフォルトの名無しさん
06/11/30 04:17:02
>>65
私も興味あります。
VC++6というか、VisualStudioのようなMDIを実現する方法。


67:60
06/11/30 04:56:11
>>66
前書き込んだ者ですけど、多分、ダイアログバーを自分で改造して
似た様な物が出来るんじゃないかと思うんですが。
設置したコントロールもダイアログの状態によって位置、大きさを変更する等して。
外観は全部自分で独自に描画して似せて。
例えば、あの二本線のRebarみたいなのも自分で描画して。
CDialogBarのDDXが効かないのは、CDialogに書き直せば確かOKだった筈ですし。


68:デフォルトの名無しさん
06/11/30 19:00:30
アプリケーションの英語化作業中です
リソースを日本語版と英語版を用意して、以下のような設定にしています
 英語版ビルド時には日本語を無視
 日本語の場合には英語リソースを無視

この方法でビルドした場合、ダイアログに直接貼り付けてあるStaticテキストや
ボタンのCaption等は正しく言語の切替が行われていますが
StringTableから読み込んで表示する場合、英語版が全て空白になってしまいます

正しく読むにはどうしたらいいでしょうか?

69:デフォルトの名無しさん
06/11/30 19:09:49
英語と日本語でそれぞれプロジェクト作って比べてみれば馬鹿でもわかる。

70:68
06/11/30 19:43:41
すみません、解決しました
開発しているのはプラグインなのですが、対象となるソフトの言語設定を変更したら上手く行きました

71:49
06/11/30 22:37:56
>>55

CDockContextの派生クラスを作成し、以下の3つをオーバーライド。
・virtual void StartResize(int nHitTest, CPoint pt);
・void Stretch(CPoint pt);
・BOOL Track();
StartResize()とTrack()は、CDockContextのものをそのまま手を入れずにコピー。
Stretch()は、例の部分をVC2005版に修正し、それ以外はそのままコピー。
そのほかに、これらの関数で使われている定数や構造体の宣言をそのままコピー。

CToolBarの派生クラスを作成し、EnableDocking()をオーバーライド。
m_pDockContext = new CDockContext(this);
の部分を、上のCDockContextの派生クラスをnewするように修正し、
それ以外はそのままコピー。

というソースファイルを作成し、
SDIのツールバーをこのCToolBarの派生クラスに置き換えてみたところ、
無事にセカンダリモニタ上でもサイズできました。

「当方では一応成功」っていうのも、やはりこのような感じなのでしょうか?

72:62
06/11/30 22:54:50
とりあえずウィンドウをDLL側で生成して表示させることはできました
フレームとビューとドキュメントをCCreateContextで連結させるのに苦労しました
上手に表示されたときはとってもハッピーになりました

さて、申し訳ないですが本日も質問があります
それはビュー(CFormView)に張り付けたダイアログリソースについてです
なぜか分からないですが、呼び出しアプリケーション側のダイアログリソースに置き換わってしまいます
DLLのダイアログリソースが表示されません
Resource.hが怪しいと思っていますが、どうすれば解決できるのか分かりません
アドヴァイスを頂けませんか?

あと、昨日の質問が残っています
>>62の後半、メモリ開放についてです
CFormWndのインスタンスを持っているのはDLL側です
ユーザが閉じるボタンやAlt+F4でデストロイしたことを察知して2度デストロイやdeleteするのを防ぎたいです
大変にクリティカルな問題なのでとても悩んでいます
インターネット検索や書籍で解決策を探していますが、まだ解決には至っていません
アドヴァイスをお願いします

73:デフォルトの名無しさん
06/12/01 00:14:31
>>72
相変わらずFrameの位置が不明瞭です...

次の3つの内から一つを選択しなさい。
1.Exe側のCMainFrameにDLL側で作成したCFormViewを結合している
2.ExeとDLLにそれぞれFrame&Viewの対がある
3.その他

上段で上手に表示されたと書いてるけど、中段読むとFrameとViewの
結合に失敗してるし訳分からない。別な話?
下段CFormWndのbase class はCFormView or CFrameWnd ?

74:72
06/12/01 00:16:17
>>73
すみません
選択肢1が該当します

75:デフォルトの名無しさん
06/12/01 00:27:52
dll内でnewしたインスタンスはdll内でdeleteしないといけないのでしょうか。


76:デフォルトの名無しさん
06/12/01 00:49:13
>>74
であれば、Viewをdeleteする必要はない。
FrameとViewが正しく結合されていれば、exe側Frameが閉じられる際に自動で削除される。
CView::PostNCDestroy()参照。

77:デフォルトの名無しさん
06/12/01 01:11:51
>>75
うん

78:デフォルトの名無しさん
06/12/01 01:18:01
>>75
例えば開発時に、EXEがReleaseでDLLがDebugだとすると。
メモリ管理のランタイムが別になるんで、EXEでnewしたメモリをDLLで開放しようとすると、
当然そんなメモリは管理してないから落ちてしまうと。

79:デフォルトの名無しさん
06/12/01 01:27:38
exe-dllで使用しているMFCのバージョンが同じで >>78の言うことに気をつけていれば
問題ないんじゃないの?
77は根拠を示すべし。

80:デフォルトの名無しさん
06/12/01 06:53:15
>>79
別のアプリで確保したメモリを別のアプリで解放できるか?って話しになるんじゃない?

81:デフォルトの名無しさん
06/12/01 09:12:04
この子は何をほざいているのだろう・・・

82:デフォルトの名無しさん
06/12/01 10:26:11
>>79
バージョンが同じでも、MFCをスタティックリンクしてるとダメだよ。

83:デフォルトの名無しさん
06/12/01 14:28:49
論点がばらけ過ぎてる

84:55
06/12/01 19:42:03
>>71
そんな感じです。というより全く同じですね。
VC6ではやむを得ないと思います。

>>65-67
URLリンク(www.codeproject.com)
URLリンク(www.codeguru.com)
スクリーンショット見た感じ、↓のが参考になるかも。
URLリンク(www.codeguru.com)
URLリンク(www.codeguru.com)
URLリンク(www.codeproject.com)

>>62&>>72
どっかのスレで参考になる文献はないかと聞かれたから
URL貼ったんだが全く読んでないんだな。
考えられる原因の一つは、delete this;して自殺するクラスがあるということ。
CFrameWndやCViewがまさにそういうクラスなのでその可能性があるんじゃない?
76も答えてくれてる通り。


85:デフォルトの名無しさん
06/12/02 16:41:12
VC++.NET2003で開発しています。

MDIから別プロジェクトの画面を子画面として表示させたいのですが、
どういう風に作ればいいのでしょうか。

86:デフォルトの名無しさん
06/12/02 17:26:41
またMDIか

87:デフォルトの名無しさん
06/12/02 17:32:47
このまえ質問してたやつはどこに消えた?

88:49
06/12/03 13:05:02
>>84
やはりこういう派生になるのですね。安心しました。
VC7でも同じ問題が発生するようで、VC2005じゃないと直ってないようです。

89:40
06/12/03 16:05:47
>CViewのメニューなりからのイベントでCFormViewを開く時は、
の続きで、Viewの差し替えは、Viewクラスでのメニューイベントハンドラーで
CWinApp* myapp=AfxGetApp();
CDocTemplate* mydoctemp=(CDocTemplate*)RUNTIME_CLASS(CDocTemplate);
POSITION myps=myapp->GetFirstDocTemplatePosition();
mydoctemp=myapp->GetNextDocTemplate(myps);//テンプレートリストの1番目を選択するイテレータ
mydoctemp=myapp->GetNextDocTemplate(myps);//テンプレートリストの2番目を選択するイテレータ
mydoctemp->OpenDocumentFile(NULL);
でドキュメントテンプレートに入れられた2番目のViewを新規子ウィンドウで表示できたよ

90:デフォルトの名無しさん
06/12/04 13:59:24
ダイアログにタブコントロールを乗せ、複数のリストビューの表示をタブで切り替える
ソフトを書いていたんですが、タブに重ねたリストビューの列サイズを操作すると
リストビューの表示が乱れる現象が出てしまいました。

URLリンク(www.uploda.org)
サンプルプロジェクトです。VC2005で作りました。
URLリンク(www.uploda.org)
1つめのリスト。こういう感じで一番右の列境界をタブの外へ右にドラッグすると
スクロールバーが現れます。通常の動作です。
URLリンク(www.uploda.org)
2つめのリスト。1つ目と同じく一番右の列境界を右へドラッグするとスクロールバー
が現れるタイミングで表示が乱れます。

どうして2つ目のリストでのみ表示が乱れるのか悩んだ結果、ダイアログのリソース
定義ファイル中の、
> CONTROL "",IDC_LIST1,"SysListView32",LVS_REPORT | (以下略)
> CONTROL "",IDC_TAB1,"SysTabControl32",0x0,7,7,173,186
> CONTROL "",IDC_LIST2,"SysListView32",LVS_REPORT | (以下略)

> CONTROL "",IDC_LIST1,"SysListView32",LVS_REPORT | (以下略)
> CONTROL "",IDC_LIST2,"SysListView32",LVS_REPORT | (以下略)
> CONTROL "",IDC_TAB1,"SysTabControl32",0x0,7,7,173,186
と順番を入れ替えると表示が乱れなくなりました。逆に、タブの行をリストの先頭
に持っていくと今度は両方のタブでリストの表示が乱れるようになります。

結果オーライといえばそれまでなんですが、どうしてこれで問題が解決するのか納得が
いきません。リソース中の定義順が何に影響しているのでしょうか?

91:デフォルトの名無しさん
06/12/04 14:05:47
普通はプロパティシート

92:デフォルトの名無しさん
06/12/04 14:46:26
>>90
Zオーダーの問題じゃね?

93:デフォルトの名無しさん
06/12/04 16:30:03
Zオーダーの問題

94:90
06/12/04 22:53:30
確かにZオーダの問題でした。どうもありがとうございます。

リソース定義の順番がZオーダになるというのが将来にわたって保障された
仕様なのかどうかが疑問なので、コントロールを重ねる場合のZオーダは
きちんとSetWindowPosでコード中に書いておくことにします。

95:デフォルトの名無しさん
06/12/06 06:13:15
VC6.0のMFCで作ったプログラムを実行したときにレジストリへ一切書き込まないようにしたいのですが
HKEY_CURRENT_USER\Software\Microsoft\Windows\ShellNoRoam\MUICache
に VS_VERSION_INFO の FileDescription の値が書き込まれてしまいます。
FileDescription を消しても実行ファイル名が変わりに書き込まれてしまいます。
どうしたら書き込まないように出来るでしょうか?

96:デフォルトの名無しさん
06/12/06 10:01:56
そのキーを書込み禁止にすると(・∀・)イイヨ!!

97:デフォルトの名無しさん
06/12/06 23:59:45
CFtpConnectionを使ってFTPクライアントを実験的に作ってみたのですが、
PASVモードを使ったときにどのポートが使われているかというのは
どうやって取得すれば良いでしょうか?

98:デフォルトの名無しさん
06/12/12 21:25:29
CListCtrl (以下、リスト)をレポート形式で使用しているのですが、
このリストの特定セルだけ背景色を変えるにはどうしたら良いですか?
ステータス値に応じてセルの色が変わるような機能を実現したいのですが……

99:デフォルトの名無しさん
06/12/12 21:26:36
ダイアログ上に複数のスタティックなコントロールを配置しています。
各コントロール毎に違う背景色を設定したいのですがどのようにすればよいのでしょうか?
OnCtlColor()メソッド内でコントロールの判定ができればよいと思うのですが・・・。
どなたかご教授の程よろしくお願い致します。

OSはWinXP SP2、開発環境はVC++ 2005です。

100:デフォルトの名無しさん
06/12/12 21:45:51
>>98
カスタムドローじゃねぇの?

>>99
普通にウィンドウハンドル比べたらどうよ?

101:98
06/12/12 21:47:33
>>100
無知で申し訳ないのですが、カスタムドローとはどのようなものですか?

102:デフォルトの名無しさん
06/12/12 21:55:03
>>101
URLリンク(www.google.co.jp)

103:98
06/12/12 21:57:44
>>102
すみません、自分で検索するべきでした
どうもありがとうございました

104:99
06/12/12 22:00:20
>>100
レスありがとうございます。

if(GetDlgItem(IDC_STATIC_COLOR1) == pWnd){
AfxMessageBox(L"一番目のコントロール");
}
//以降コントロールの数分else if

試しにこんなコードでやってみたのですが引っかかりませんでした。
比較処理が悪いのでしょうか?



105:デフォルトの名無しさん
06/12/12 22:06:07
MFCってpWnd->m_hWnd == GetDlgItem(IDC_STATIC_COLOR1)->m_hWndってやらなくてもいいんだっけ?
まあ、駄目だったら、そもそもIDC_STATIC_COLOR1が本当にそいつの直下に配置してあるコントロールなのかどうなのか
ってところがあやしいんじゃね?

106:99
06/12/12 22:22:41
>>105
OnInitDialog内で
GetDlgItem(IDC_STATIC_COLOR1)->SetWindowText("あいう");
で文字は表示されたので問題はないと思うのですが・・・。
もう少し調べてみます。


107:99
06/12/12 22:31:54
>>105
すみません、教えていただいた
pWnd->m_hWnd == GetDlgItem(IDC_STATIC_COLOR1)->m_hWnd
でできていました。(メッセージボックスが表示されていなかったのでできていないと思っていました)
どうもありがとうございます。

108:デフォルトの名無しさん
06/12/12 22:38:02
それはえがった

109:デフォルトの名無しさん
06/12/13 16:35:12
VC6を使って、MDIアプリにMDIタブを実装したい
まずは、CMainFrame に MDIタブ用の CDocBar を配置したいのだが、
どこをどうオーバーライドしたらいいんだ?

CMainFrame::recalcLayout() あたり?


110:デフォルトの名無しさん
06/12/13 17:02:48
またお前か

111:デフォルトの名無しさん
06/12/13 19:25:44
その前にMDIの作り方は間違っていないのかね?
なんだかこの間からぶち当たった問題をことごとく質問してないか?

112:デフォルトの名無しさん
06/12/13 19:32:03
相談室だから質問しています

113:デフォルトの名無しさん
06/12/13 19:34:02
>>112
相談しようぜ。
MDIの基本的な部分はOKなん?

114:デフォルトの名無しさん
06/12/13 19:52:36
ここは自分でできもしないことを相談する所か?

115:デフォルトの名無しさん
06/12/13 20:17:28
まあ、MFCスレってここしかないんだから、そう厳しいこといわんと。
MFCって結構むずいじゃん。
俺、ドキュメントビューアーキテクチャーとかいう仕組み覚えるのに何日も必要だったぞ。
まず、ドキュメントビューアーキテクチャーの構造なんて大して重要なもんだと思ってなかったし(SDIで組んでたのもあって)。
この状態でMDIプログラミング特攻すると、はっきりいってハマルじゃんw

116:デフォルトの名無しさん
06/12/13 20:57:27
プロパティシートについて質問があります。
ダイアログをいくつか作成(このときフォントをMSゴシックの12ptに変更)し、
各ダイアログ毎にクラスを作成(CPropertyPageクラスの派生クラス)して
メインメニューに[プロパティ]項目を追加、そのイベント内で
・プロパティシートのインスタンス生成
・プロパティページをプロパティページにAddPage
・DoModalで表示
しています。
このとき、表示された各ページのフォントサイズが標準のMS UI Gothicの9pt
で表示されてしまっています。なのでCPropertySheetの派生クラスを作り、
OnInitDialog内でフォントサイズの変更を行ってみたのですが変化なしでした。
なぜこのような現象が起こるのでしょうか?

117:デフォルトの名無しさん
06/12/13 21:00:50
プロパティシート使ったことないけど
タブコントロールなら、全ページフォントを設定する必要があるな。
プロパティシートにもそんなのあんじゃね?(適当w)

118:デフォルトの名無しさん
06/12/13 21:10:57
OnInitDialog内でGetPage()->SetFont();は行っているのですが
それでも変わらないんですよ。各ページのコントロールのサイズも
ちっちゃくなってますし。全ページのコントロールの位置、サイズ、フォントを
設定しないといけないんでしょうか。

119:デフォルトの名無しさん
06/12/13 21:42:18
CPropertySheet フォント で検索

120:デフォルトの名無しさん
06/12/13 21:44:25
MDIの基本的な部分はたぶんオケ

だからおいらの相談に答えてくれよー

121:デフォルトの名無しさん
06/12/13 21:46:33
>>119
あ、やっぱ、手動なんだw

122:デフォルトの名無しさん
06/12/13 21:48:25
>>120
ドキュメントビューアーキテクチャ(なげぇなw)の理解は大丈夫ということでOK?

123:デフォルトの名無しさん
06/12/13 21:57:52
>まずは、CMainFrame に MDIタブ用の CDocBar を配置したいのだが、

MFCにCDocBarなんてあったけ?

124:デフォルトの名無しさん
06/12/13 22:20:15
>>123
すまん CDockBar だった

CDockBar はアンドキュメンテッドなクラスで、CControlBar を配置するための滑走路みたいなものだよ

125:116
06/12/13 22:43:28
>>119
SendMessageToDescendants()?でフォントは変更できましたが、
サイズとかの変更の仕方が分かりませんでした。

126:デフォルトの名無しさん
06/12/13 23:09:57
MFCを理解しようとしないで自分のやりたいことだけ質問する馬鹿ばっかりだな

127:デフォルトの名無しさん
06/12/13 23:33:37
MFCのすべてを理解してるなら、すべての質問・相談にちゃっちゃ答えて神になってくれ

128:デフォルトの名無しさん
06/12/13 23:47:28
何のためにソースがついてるんだろ

129:デフォルトの名無しさん
06/12/13 23:49:05
非効率だよね。
まず、全体っちゅーか概要ぐらいは理解しないと
なにやるにも知ってる人間にお伺いを立てないと何もできなくなっちゃうぞ。

130:デフォルトの名無しさん
06/12/14 01:57:25
なんかMFC使うほうがかえって面倒くさそうだ

131:デフォルトの名無しさん
06/12/14 03:22:11
馬鹿じゃねぇの

132:デフォルトの名無しさん
06/12/14 07:02:17
>>130
そういうときもある。

133:デフォルトの名無しさん
06/12/14 09:06:58
コントロールのサイズと位置はピクセル単位じゃなくてダイアログベース単位で、
ダイアログベース単位はフォントの幅が元になってる。
だからダイアログのフォントを変えると
コントロールのサイズと位置もフォントに比例して変わる。

このフォントサイズはダイアログを作る時に指定した
ダイアログボックステンプレートに定義されている。
ダイアログを作った後でフォントを変えても
コントロールは既に作成されてしまっているから
コントロールのサイズと位置は後で指定したフォントには影響されない。

以上ここまでMFCに限らずWin32でも同様

プロパティシートがリソースで定義されたダイアログのフォントを無視しているということは
たぶんメモリ上に読み込んだダイアログボックステンプレートのフォントを書き換えてから
その変更を加えたダイアログボックステンプレートでダイアログを作っているのではないか
と推測されるけど、あとはCPropertyPageのソース等を読めばわかることだから省略

134:デフォルトの名無しさん
06/12/14 10:51:38
  ☆ チン

        ☆ チン  〃  ∧_∧   / ̄ ̄ ̄ ̄ ̄ ̄ ̄
          ヽ ___\(\・∀・)<  MDIタブ実装方法 まだー?
             \_/⊂ ⊂_)_ \_______
           / ̄ ̄ ̄ ̄ ̄ ̄ ̄/|
        |  ̄  ̄ ̄ ̄ ̄ ̄ ̄:| :|
        |           .|/

135:デフォルトの名無しさん
06/12/14 11:22:30
ソースを読めばわかることだから省略

136:デフォルトの名無しさん
06/12/14 11:43:33
MDIタブのこと書こうか迷ってたんだけど、AAみて踏ん切りがついたよ。

137:デフォルトの名無しさん
06/12/14 13:05:50
MDIタブの何を書こうかと迷ってたんだ?

138:デフォルトの名無しさん
06/12/16 17:26:02
Button(OKやCancelや適用など)をDisableにしたいのですが、どの関数を使うのですか?
SetCheck()かと思ったのですが違うようでした。。

139:デフォルトの名無しさん
06/12/16 17:46:32
>>138
基本クラスのメンバEnableWindowで

140:デフォルトの名無しさん
06/12/16 18:12:46
なるほど…
やってみます。ありがとうございました。

141:デフォルトの名無しさん
06/12/17 19:17:51
リストコントロール(CListCtrl)をリードオンリにするにはどうすれば良いですか?

142:デフォルトの名無しさん
06/12/17 19:21:10
2つ目の質問です

ツリーリストコントロールって標準で存在しませんか?
存在しない場合はどうすれば使えますか?
MFCで作ったフリーソフトでツリーリストが使われていたので、
何らかの方法でできるのではないかと考えているのですが・・・

ちなみに、今の自分の技術力では自作は無理です

143:デフォルトの名無しさん
06/12/17 19:25:35
3つ目の質問です

MDI子ウィンドウのビュー(フォームビュー)でリストコントロール(CListCtrl)を使っているのですが、
他の子ウィンドウがリスト部分の前に重なった後、リスト部分をクリックしてリストがある子ウィンドウを
アクティブにすると重なっていたリスト部分だけが再描画されません
原因はまったく不明です
どのようにすれば子ウィンドウがアクティブになった時に正常に再描画されるようにできますか?

144:デフォルトの名無しさん
06/12/17 19:29:21
最後の質問です

MDI子ウィンドウのビューでリストコントロールを使っているのですが、
子ウィンドウのサイズ変更にあわせてリストのサイズを動的に変更するには
どのようにすれば良いですか?

VC#ではプロパティ画面で簡単に設定できたのですが、
VC++にはないのでとても困っています・・・





以上4つ質問させて頂きました
何かご存知の方は、ご回答をよろしくお願いしますm(_ _)m

145:デフォルトの名無しさん
06/12/17 19:37:53
最後のやつの答えは
子ウィンドウのサイズ変更にあわせてリストのサイズを動的に変更する

146:デフォルトの名無しさん
06/12/17 19:45:00
MDI野郎の質問は意味不明

147:デフォルトの名無しさん
06/12/17 19:51:36
具体的にはOnSizeとかOnSizingとかOnExitSizeMoveとか用途に合わせて使うと吉。

148:デフォルトの名無しさん
06/12/17 19:53:22
>>141
普通リードオンリーでできんじゃねぇっけ?
リソースファイルの方の設定に編集できるとかできないとかそういうプロパティあった希ガス。

149:デフォルトの名無しさん
06/12/17 20:00:56
>>142
昔、俺がみたのは自力で描画してたのしかみたことないな。
今、どうなってるのかはよくわからん。

150:デフォルトの名無しさん
06/12/17 21:27:01
>141-144
勉強してないの丸わかりなんだけど
よくリストコントロール表示できたね
どっかからソースぱくってきた?

151:デフォルトの名無しさん
06/12/17 21:43:34
たしかにこうなんもかんもわからんようだとどうしようもないなw

152:デフォルトの名無しさん
06/12/18 01:37:33
いつも質問しっぱなしで消えて行く人と文体がそっくりだな

153:デフォルトの名無しさん
06/12/18 16:59:07
お願いします。MFCを使い大量の点を打って画像を描画するプログラムを作っています。
点の数は数千を越えていると思うのですが かなり処理に時間がかかります。

自分なりに色々調べたところ SetPixelは遅い ということがわかりました
同時に BitBlt とか 裏画面 などと 高速化に関するワードも出てきましたが
全く分かりませんでした
この言葉で全て解決しようとするのが悪いのですが 初心者です。
しかし、時間が本当に無いので時間をかけて勉強して… ができません。

ちなみに 点は一色です。 SetPixelの遅さを解決する方法で
まだ分かり易いだろう と思う方法を教えていただけませんか?

154:デフォルトの名無しさん
06/12/18 17:15:42
かなり遅いって具体的に何秒?たった数千なら一瞬のはずだけど...

155:デフォルトの名無しさん
06/12/18 17:27:01
えっ・・・ そうなんですか?
具体的にはループ回数が3万でそのうちの一部の点を
描画しているので、最大でも3万ですね
1万は越えているかも知れませんが…

時間は3分から5分程度でした。

156:デフォルトの名無しさん
06/12/18 17:31:20
うちのPCは最新鋭からは程遠いセレロンだけど10万個の点をSetPixelで
描いても0.1秒ぐらいだったよ。(裏画面とか未使用)
描画以外の部分に時間かかってるんじゃないかな。

157:デフォルトの名無しさん
06/12/18 17:35:59
配列に直接描画すればいいんじゃない?

158:デフォルトの名無しさん
06/12/18 17:39:17
そうでしたか… スペック的には確実問題になるほどではありません。
ループ回数を増やすと比例関数的に時間も延びたので
てっきりそこが問題だと思っていました。

そうなるとどこに時間がかかっているのか全く分かりませんね…
ランダムウォークさせているのんですが そこか
1024*768もの配列を作って その中身全てを参照(検索)するという作業を
何度かしているのも原因かもしれませんね。
mallocなんかも全く使っていませんし…

ループ回数をこれ以上にするとエラーになり途中で動作が止まってしまうのも
同じ原因から来ているのかも…

しかし ここまでくるとここで相談させてもらう内容ではなくなってしまいますね。

159:デフォルトの名無しさん
06/12/18 17:42:35
1024*768*30000=230億強
それは遅いだろ...

160:デフォルトの名無しさん
06/12/18 17:57:38
>BitBlt とか 裏画面 などと 高速化に関するワードも出てきましたが全く分かりませんでした
>初心者です
>時間が本当に無いので時間をかけて勉強して… ができません。

結論: 無理

161:デフォルトの名無しさん
06/12/18 17:57:46
最後に一回だけ描画すればいいのに
いちいちSetPixel使うからだよ。

162:デフォルトの名無しさん
06/12/18 18:01:51
えっと 最後に一回だけ描画してます。

まぁ特に考えてたわけではなく、むしろ本当は描画の
様子が分かるように1回1回点を打ちたかったのですが
それができなくて 最後にだけ描画してます。
(点を打つ配列に目印をいれて最後にその部分だけ描画)

結論を言うと そのループ及び巨大な配列の中身を参照するのに
時間がかかってるというわけなんですね・・・

>>160 ってことでFAですかね。

検索の仕方や配列の使用法などを再考してみますね。
こんなくだ質に付き合ってくださってありがとうございました。


163:デフォルトの名無しさん
06/12/18 18:13:41
SetPixelをループに入れてる時点で一回だけじゃないじゃん。

164:デフォルトの名無しさん
06/12/18 18:17:04
GDIにじゃなくてメモリに対して書くようにすればいいんじゃないの?

165:デフォルトの名無しさん
06/12/18 18:20:29
たった一色ならcharで1024*768の配列をnewして
0か1を直接書き込めばいいじゃない。

その後BMPに変換すれば?

166:デフォルトの名無しさん
06/12/18 18:54:30
正直MFCと全然関係ない

167:デフォルトの名無しさん
06/12/18 19:57:42
1280*1024の画面全体の約130万ピクセルでも数秒だね
遅いというのは一瞬じゃないということ
自分で試さずに質問するのはやめてほしい。

168:デフォルトの名無しさん
06/12/19 00:26:28
>>162
そういう時は、SetPixelだけをコメントアウトしてみる。
そうすれば、それが犯人かどうか分かる。

169:デフォルトの名無しさん
06/12/19 00:53:12
質問者じゃないけど試しにBitmapBits弄ってみたら
130万pixelなんて問題にならないぐらい強烈に早いね。
今後使う機会があるかは微妙だけど勉強になったよ。

>>170 スレ違い房乙

170:153です
06/12/19 00:55:54
さらにレスしていただいたんですね。
>>163
確かにループには入ってますね
でもループもしないで1回だけ なんて できるんですか
>>164
そのような方法がある事は調べていたときにわかったんですが
なかなか理解できなかったんですよね
>>165
今は理解できないんで ちょっと考えて見ます^^;
ありがとうございます。
>>166
ですね。 158で自分でも言ってますが。 すみませんでした。
>>167
そうなんですか。 >遅いというのは一瞬じゃない そうですね
自分で試さずに とは 何のことでしょう?
確かに SetPixelに時間がかかっていたかどうかは
自分で画面全体にSetPixelで塗りつぶしてみれば分かったんですね…
そうだ と思い込んでしまったので思いつきませんでした ごめんなさい。

171:デフォルトの名無しさん
06/12/19 01:15:49
>>168さんもありがとうございます。
そんな方法もありますね 次回から参考にします!
>>169
スレ汚しすみませんでした。

172:デフォルトの名無しさん
06/12/19 02:51:30
>>171
つーか、普通にSetPixelとGetPixelが遅い。

GDI+を使っているならこれで速くなるっぽいことが書いてある。
URLリンク(junki.lix.jp)

173:デフォルトの名無しさん
06/12/19 08:21:41
> 描画しているので、最大でも3万ですね
> 1万は越えているかも知れませんが…
>
> 時間は3分から5分程度でした。


描画しているのは最大でも3万で時間は3分から5分

174:デフォルトの名無しさん
06/12/19 14:48:18
とりあえず、ビットマップ作ってメモリDCで選択して
そこに描画してBitBltするという、昔ながらのやり方を
試すのが今後のためにいいと思うが。

175:153
06/12/19 14:54:29
>>172
VC++ のMFCです。
>>174
そうですよね。
いい機会ですし勉強して使えるようにしたいと思います。

176:デフォルトの名無しさん
06/12/19 16:20:57
ほとんどMFCと関係ない

177:デフォルトの名無しさん
06/12/19 23:24:44
では MDIタブの実装方法についてお話してください
よろしくおながいします

178:デフォルトの名無しさん
06/12/19 23:36:11
mfcにMDIタブなんてものは存在しない

179:デフォルトの名無しさん
06/12/19 23:58:47
イヤです

180:デフォルトの名無しさん
06/12/20 10:36:29
>>178
存在しないから作るんですよ

181:デフォルトの名無しさん
06/12/20 10:49:58
じゃあmfc関係無いのでは

182:デフォルトの名無しさん
06/12/20 11:18:15
>>141 LVN_ITEMCHANGING
>>142 LVITEM::iIndent'
>>143 WS_CLIPSIBLINGS

183:デフォルトの名無しさん
06/12/20 12:37:11
MFCのMDIを拡張して作るんだから関係あるし、難易度が高い
MFCを使わず、まったくゼロから MDIタブを作るのならそれほど難しくはない

と混じれ酢してみる

184:デフォルトの名無しさん
06/12/20 13:08:57
決まった作り方が存在しないから好きなように勝手に作れ

185:デフォルトの名無しさん
06/12/20 13:18:05
好きなように作りたいんだけど、作り方がわからないんだよぉ〜

186:デフォルトの名無しさん
06/12/21 01:17:54
ダメです

187:デフォルトの名無しさん
06/12/21 10:24:22
MDIタブを作るには、フレームウィンドウの上部(or左or右or下)にMDIタブのための領域を確保する必要がある
そのためには void CMainFrame::RecalcLayout(BOOL bNotify) をオーバライドすればいいぞ
どうオーバライドするかは自分で調べろ

188:デフォルトの名無しさん
06/12/23 01:28:04
イヤです

189:デフォルトの名無しさん
06/12/23 14:47:20
VC++6.0 WinXPProで開発を行っております。
XPログオン時のユーザ名とパスワードが正しいかどうかを、開発したプログラム上で
確認したいと思っているのですが、どのようにすればよろしいでしょうか。

190:デフォルトの名無しさん
06/12/23 14:51:25
誤爆?
ここはライブラリの専用スレですよ

191:デフォルトの名無しさん
06/12/23 14:55:43
>>190
スイマセン、他スレで聞いてきます。

192:デフォルトの名無しさん
06/12/23 15:26:31
ウィンドウにスクロールバーがあるかどうかを調べたいのですが、
どうすれば取得できるでしょうか?

193:デフォルトの名無しさん
06/12/23 15:35:00
WS_HSCROLLやWS_VSCROLLスタイルが付いてるか調べればいいんじゃないかな

194:デフォルトの名無しさん
06/12/23 15:42:35
GetWindowLongで取得すればいいのでしょうか?
色々調べてみたのですが、GetWindowLongの使い方がいまいちよく分からないです。。
具体的にどう使えばいいか、ご教授願えますでしょうか(><

195:デフォルトの名無しさん
06/12/23 15:49:27
MSDN見ろよ

196:デフォルトの名無しさん
06/12/23 15:56:33
MSDN見てます。
LONG lStyle = ::GetWindowLong(m_hWnd, GWL_STYLE);
で取れると思うんですけど、そこからどうすればいいか分からないんです。
どこを見れば分かりますか?

197:デフォルトの名無しさん
06/12/23 16:04:12
ビット演算も知らんのか?

198:デフォルトの名無しさん
06/12/23 16:07:05
MFCの質問じゃない

199:デフォルトの名無しさん
06/12/23 16:20:22
ビットで入ってるんですね。
MFC以前の問題ですか・・・
もっとよく調べてきます。

200:デフォルトの名無しさん
06/12/23 23:28:32
MFCとは関係ないね>>199

201:デフォルトの名無しさん
06/12/24 22:58:19
質問があります。
現在、ダイアログAのボタンを押すと、ダイアログAを隠して
ダイアログBをモードレス表示し、
表示されたダイアログBのボタンを押すと、ダイアログBを隠して、
ダイアログAをモードレス表示するツールを作成しております。

そこで、ダイアログAのボタンを押すと、ダイアログAを隠して
ダイアログBをモードレスで表示することは出来たのですが
モードレスで開いたダイアログBのボタンを押すと、
ダイアログAをモードレスで開く方法がわかりません。
教えてください。
よろしくお願いします。

202:デフォルトの名無しさん
06/12/24 23:20:22
ダイアログAがやったのと同じ事をダイアログBでやればいいだけじゃん

203:デフォルトの名無しさん
06/12/25 05:05:35
>>202
エスパー値が低いのに初心者の質問に答えるな。話がややこしくなる。
要は循環参照になっちまってコンパイルできねぇんだろ?

つまり、
メインウィンドウ→ダイアログA→ダイアログB→ダイアログA→ダイアログB
って構造だとダイアログAとダイアログBが循環してしまって駄目なわけだ。
なので

メインウィンドウ→ダイアログA
          →ダイアログB

としてメインの方でダイアログAのボタンX、ダイアログBのボタンXの
内容を処理するようなもんを作る必要があるとそういうことだろ?
この処理をやるにはダイアログAとBのインスタンスはメインの方にもったほうがいい。
そんでメインの方で
1.ダイアログAがあったら消して、ダイアログBを出す処理
2.ダイアログBがあったら消して、ダイアログAを出す処理
を実装する。
んで、ダイアログAのボタンXでは1を発動させるような処理(親にSendMessageで独自のメッセージ飛ばすのがいいかな?)
んで、ダイアログBのボタンXでは2を発動させるような処理
を組めば完成とそういうことだ。多分w

204:デフォルトの名無しさん
06/12/25 08:32:31
Windowsの電卓の10進と16進の切り替えがそんな感じだな
あれは表に出ない親ウインドウがあってそこから2つのダイアログを切り替えてる
しまった、ここまで書いて全然MFCと関係ないのに気がついた

205:デフォルトの名無しさん
06/12/25 14:39:50
>203は別に独自のメッセージである必要もないね。
MFCなら仮想親ダイアログにメンバでABダイアログがぶら下がっているだろうから
ダイアログからは親のメンバを呼ぶだけでいい。

>>204
ほ〜らMFCらしくなったでしょw

206:デフォルトの名無しさん
06/12/25 20:24:54
なんですぐMFCと関係無い方向に行くんだ?


207:デフォルトの名無しさん
06/12/25 20:25:25
はっ
おまいらちゃんとMFCがわかっているのか?

208:デフォルトの名無しさん
06/12/25 21:03:39
>>206
行くっつぅか元々>192からしてMFCと・・・

209:デフォルトの名無しさん
06/12/25 21:27:26
APIでウィンドウも出せないくせにMFC使うな
と誰かが言ってた。

210:デフォルトの名無しさん
06/12/25 21:50:49
VS2005 MFCを使用しています。
プロパティシートでSendMessageToDescendants()を使用し、
各ページのフォントサイズを変更しているのですが
なぜかリストコントロール内のフォントサイズだけ変更されません。
(ヘッダーは変更されていました。)
SendMessageToDescendants()を使用せず、リストコントロール
のSetFont()を使用すれば変更できるのですが、リストコントロール
に合わせてすべてのページですべてのコントロールにSetFontをするのは
避けたいです。なにかいい方法はありませんでしょうか?

211:デフォルトの名無しさん
06/12/25 22:06:20
>>210
この前の質問どうなったっけ?

212:デフォルトの名無しさん
06/12/25 22:23:31
>>211
今までリストコントロールを利用していないシートの
コーディングを行っていたのでてっきりうまく変更されていた
ものとばかり思っていたのですが、リストにデータを挿入して
表示したところリスト内のサイズだけ小さかったので
再度質問させていただきました。


213:デフォルトの名無しさん
06/12/26 01:30:22
1. 専門用語を知らないMFC初心者が質問
2. 知ってる人が専門用語をあまり使わずに解説
3. 理解できない別の知ったか初心者が 「MFCと関係ない」
4. 質問者が3にむかついて失踪

最近この流れが多い。3の人は1年ぐらいROMって欲しい。

214:デフォルトの名無しさん
06/12/26 08:50:07
すいません教えてください。
C/C++を一通り勉強して、mfcでビュッフォンの針のシミュレーションプログラムを
作ろうと思ってるんですが、ダイアログベースで、ピクチャボックスに描画しようとして
も上手くいきません。CClient の矩形をCRectで取り
bottomとrightを数値で覚えさして、シミュレーション用の横棒を引くため
bottomを横棒の数で割り、movetoとlinetoでそれぞれの位置に線を引いたのですが
(用は、数値が1ならクライアント領域が二等分されるようになり
数値が2ならクライアント領域が三等分されるような形)
上手く等分されません。
なにか良い方法か、サンプルのあるページがあれば教えてください。

215:デフォルトの名無しさん
06/12/26 08:57:16
描画に使った数値が合ってるかどうかぐらい調べてから質問しろよ

216:デフォルトの名無しさん
06/12/26 08:59:08
シミュレーションの前に、簡単な線でも描けるようになってから質問しろよ。

217:デフォルトの名無しさん
06/12/26 09:35:12
日本語でかかず、プログラムを示せや

218:デフォルトの名無しさん
06/12/26 09:58:29
デバッグメッセージで、moveto、linetoに渡す数字表示させて並べてみな

219:デフォルトの名無しさん
06/12/26 18:47:19
VC6でMDIアプリを開発しています。
子フレームを最大化した状態でドキュメントを切り替えると、最大化されない子フレームウィンドウ枠が
一瞬描画されてしまいます。
これを防ぐにはどうしたらいいのでしょうか?

220:デフォルトの名無しさん
06/12/26 19:35:30
普通に作ればいい

221:デフォルトの名無しさん
06/12/26 19:57:59
普通に作ったら 子フレームウィンドウ枠が一瞬描画 されるんだけど
これは いったい誰がだしているの?

222:デフォルトの名無しさん
06/12/26 21:20:18
お前が作ったプログラム

223:デフォルトの名無しさん
06/12/27 17:33:42
CFormViewの中に設置したレポート型のリストビューで
アイテムを右クリックしたときにポップアップメニューを
表示させてそのアイテムにのみ処理をしたいのですが

どうすればいいのでしょうか

224:デフォルトの名無しさん
06/12/27 18:50:12
簡単にできそうな気がして何が問題かよくわからん
ここで質問しなきゃわからないような何か特殊な問題あったか?

225:デフォルトの名無しさん
06/12/27 18:56:59
OnRButtonDownの追加により
リストビューで右クリックのイベントをとるまでいけたんですが
メニューの表示や選ばれたアイテムの取得方法がわかりません
簡単なら教えてくださいお願いします

226:225
06/12/27 18:57:47
今はOnContextMenuに変えています

227:デフォルトの名無しさん
06/12/27 19:06:13
特に難しい問題はないはずだから調べればわかると思う。

228:デフォルトの名無しさん
06/12/27 19:20:28
リストビューで項目の右クリックをとるのはNotify使うんじゃなかったかな
あまりにも懐かしすぎて、過去のソース見ないと思いだせんがNM_RCLICKとかあったと思う

229:219
06/12/27 19:21:19
void CMDIFrameWnd::MDIActivate( CWnd* pWndActivate )
を使って、子フレームを切り替えているのだが、このメソッドをコールすると
一瞬現在アクティブなウィンドウに WM_MDIACTIVATE が送られ、
その前後に子フレームが再描画されるとこまでわかった

どうしたら子フレームの再描画をとめられるんだ?
誰か助けて。おねがい


230:デフォルトの名無しさん
06/12/27 19:37:15
調べろカス

231:デフォルトの名無しさん
06/12/27 19:42:24
普通のMDIでもそうなるならそういう仕様
普通のMDIではそうならないなら普通のMDIと同じにすればいい

232:225
06/12/28 10:44:01
>>228
NM_RCLICKで右クリックのイベントは取れました
右クリックしたときのアイテムの取得はどうすればいいのでしょうか?

233:デフォルトの名無しさん
06/12/28 11:20:58
>>232
URLリンク(msdn2.microsoft.com)

234:225
06/12/28 11:25:06
返答ありがとうございます
調べてみたら
CListCtrl::GetFirstSelectedItemPosition
で取れるようです

235:225
06/12/28 12:24:51
次は右クリックを押したときにメニューを表示させたいんですが
表示はできましたが最初のメニューだけすごく小さいのです
サブメニューは普通に表示されます以下ソースです

CMenu menu;
CPoint posMouse;

VERIFY(menu.LoadMenu(IDR_MENU1));
::GetCursorPos(&posMouse);
menu.TrackPopupMenu( TPM_LEFTALIGN | TPM_RIGHTBUTTON, posMouse.x, posMouse.y, this);


次ページ
最新レス表示
スレッドの検索
類似スレ一覧
話題のニュース
おまかせリスト
▼オプションを表示
暇つぶし2ch

4310日前に更新/205 KB
担当:undef