What's New » この記事

WindowsSDK 備忘録 その七

備忘録七では、派生クラス CMascot のプロトタイプを取り植えず定義してみました。

メインとなるのは、CImageWindow 基本クラスから派生する CMascot 派生クラスの定義になります。備忘録四のメモで取り上げた、プロシージャから指定された関数を基本クラスから派生クラスの同名の関数に委託する処理をvirtual指定することで成立させています。

[CMascot.h]

virtual void WmPaint(); // 仮想関数。実装は各子クラスの同名の関数に委託。

[cMascot.h]

void WmPaint();

基本クラスにvirtual指定がされていることで、マスコットには、マスコットクラスのWmPaint();が、バルーン(ふきだし)には、バルーンクラスのWmPaint();にそれぞれ処理が委託されるようになります。基本クラスのvirtual指定を取り払ってしまうと、(参考)http://wisdom.sakura.ne.jp/programming/cpp/cpp30.html のサイトの実験結果からの引用にあるように、

(以下引用)
この機能は、同名のメンバ名を持つクラス間で面白い現象が発生します
メンバ名が基本クラスと派生クラスで衝突している場合
クラスを明示しなかった場合は常に自分のクラスのメンバを優先しました

と、同様の結果になります。メインの多態性についてはこれぐらいで置いといて、
もうひとつここではサブとして、static なメンバ関数内に配置されているメンバ変数の取り扱いに関してとりあげておきます。

教本では、作成した複数の小窓を登録しておくMapコンテナが、staticなメンバ関数として定義されているウィンドウプロシージャの中で使われている都合上、staticで宣言されています。そのルールは知ってたんですが、実装の仕方を知らなかったんでここで散々エラーに悩まされました(確か外部リンクエラーがでたと思う)

static なメンバ変数の実装に関するルールに関しての説明はこちらを読んでいただければいいと思います。(参考)http://www.geocities.jp/ky_webid/cpp/language/019.html
ここに、静的メンバ変数を宣言した場合、その実体の定義をクラス定義の外側に記述しなくてはなりませんと、書いてあります。

試験的な変数をCMascot.h のCImageWindow に、
static int TestNumber; // テスト用
というメンバ変数を宣言してます。

で、
[CMascot.cpp]

// 静的メンバ変数の定義(★クラス外部で行う)
int CImageWindow::TestNumber = 100;

と、いう形で実体の定義を行っています。

あとは、プロシージャ内でこのstaticなメンバ変数を呼び出して、値をログに書きだすテストを行っています。

尚、子クラスのオブジェクトは作りましたが、まだ CImageWindow::WndProc の WM_PAINT に子クラスのWmPaint(); に飛べって書いて無いので、それは次のv06e.lzh でやります。

ソースコード[v06b.lzh]

RSSが出力できてなかった点を修正

WordPress3.4 を入れなおした後から、RSSの出力がおかしくなっていた点を修正しました。

[修正の手順]
今のテーマのfunction.php にadd_theme_support(‘automatic-feed-links’); が、入っていなかったので、RSSをheadタグに書きだすように修正。

(参考)http://www.prime-strategy.co.jp/wp/391/

修正したら、ブログのindex.html を開いて、rssのlinkタグが出力されているか確認。

<link rel="alternate" type="application/rss+xml" title="気流邂逅点 &raquo; フィード" href="http://haganenomori.net/wp/?feed=rss2" />

に、出力されているので一応RSSは、配信されているのでいいけど、右サイドバーのウィジットの表示がエラーを出しているので、Wordpress管理画面より、上のlinkタグに書きだされているアドレスをコピー&ペーストして修正ヽ(`Д´)ノ

WindowsSDK 備忘録 その六

前回はオブジェクトの生成はしなかったので、今回は、 mascot.cpp に動的にオブジェクトを生成します。またレム文の形で、静的にオブジェクトを配置してみました。

プログラムを実行すると、小窓がでるようになりました。また、ログに通過点の情報を書きだしました。カーソル等のレム文は削除してすっきりさせました。

ソースコード[v05b.lzh]

WindowsSDK 備忘録 その五

その五では、CImageWindowクラスを最小限の構成で定義してみました。教本では、もう最初からフル装備になってるのですが、プロトタイプはコンストラクタ・デストラクタ・コールバック関数の三つの関数があればいいと思います。

細かいところに目を配ると、インスタンスやメインのウィンドウハンドルをCMascot.cpp 中のCImageWindow();のコンストラクタで利用するので、mascot.cpp の本文中で宣言されている HINSTANCE Instance; HWND MainWindow; の二つを取り込みたいので、mascot.h 中に extern 宣言をしてこれを使って経由して間接取り込みをしているところでしょうか。

その五での大きな注意箇所は、コールバック関数をstaticで宣言しているところでしょうか。この何故staticなのかに関しては、「なぜstaticをつけるのかという質問に対しての答え」(引用)http://d.hatena.ne.jp/bnkyshr/20110107/1294391512
に詳しく説明がされています。また教本の原文では、静的に定義されたコールバック関数内で使うカーソルに、静的メンバを割り当ててますが、これをコピー&ペーストするとややこしくなるので、レムにして標準カーソルを割り付けました。静的メンバ変数の関数外での実装に関しては、CMascotクラスの定義まで踏み込んだ時、Mapコンテナを配置することになるのでその時、触れてみようかと思います。取りあえず今は無視(・3・)

注目行は、この二か所かな..

[CMascot.h]

static LRESULT CALLBACK WndProc(HWND hwnd, UINT message, WPARAM wparam, LPARAM lparam);

[CMascot.cpp]

wcex.lpfnWndProc=(WNDPROC)&CImageWindow::WndProc;

クラスのメンバ関数をキャストしてコールバック関数として登録してるとこ。

最低限の定義と実装はしましたが、オブジェクトを生成していないので見かけ上は、プログラムを実行しても何の変化もありませんね。

ソースコード[v04b.lzh]

WindowsSDK 備忘録 その四

備忘録の四回目はメモ書きです。

参考にしている教本のPart3(P.163~)からマスコットシステムの設計に入ってますが、教本では、表示機能→スクリプトエンジンという順番で、マスコットシステムに実装してる機能をひとつひとつ解説していってます。しかし、自分のように大掴みでいいから全体の流れを俯瞰して把握したいと考えている者にとっては、焦点がぼやけて全体像が見えにくく感じられます。単純にクラスを使って画面に何かを表示するということだけに焦点を絞って考えるならば、表示機能の仕組みを理解できてればいいので、スクリプトエンジンのことはこの時点では無視して、仕掛けに関して整理してみました。

以下メモ書きより

(さらに…)

WindowsSDK 備忘録 その三

備忘録三回目は、下準備としてログを出力できるようにしておきます。ある時点での変数の中身や指定行をどう通過したかをログに出力できれば、気持ち的にもだいぶ楽になるのでmascot.cppにLog.hをインクルードします。(5行目)


// [チェック用] ログ出力用関数の宣言
#include "log.h"

とします。ログを書き出す関数に関しては、今は閉鎖されてしまっているみたいですが、電子通さんというサイトさんで公開されていたログを書き出すための関数が使いやすかったのでそちらを使わせてもらいました。ログの初期化をかけたら、あとはコードに埋め込んであるように文字列を出力するように指定します。尚、可変引数をとることができるので、Log(“Aの中身は %s です\n”, str); の様な書き方もできます(重宝してます)。書き出したログは、初期化時に与えた名前でプロジェクトフォルダ内に出力されます。今回の場合は、check.log になります。

ソースコード[v03.lzh]

WindowsSDK 備忘録 その二

VSE2012がどんな感じかは前回ので分かったので、二回目以降は「空のプロジェクト」でプロジェクトを作り、一回目で自動的に作られた基本コードと以下の教本から必要なコードをコピー&ペーストしながらクラスを中心にしたWindowsプログラムの流れを備忘録では追ってみようかと思います。

教本としては、「デスクトップマスコットを作ろう!!」という本が自分が読んだ本の中では、比較的シンプルにC++とWindowsSDKを使ってアドベンチャー系ゲームの雛形を解説しているので、これを利用することにしました。

Amazon でのレビュー記事で述べられているように入門書としていい本かといわれると「?」な感じの本ですが、それでも一通りの流れは一冊の本の中で説明されているのと、directxやMFCを使ってないところやプロジェクトを構成するファイル数もなんとかなりそうな数で済んでいるので、とっつきやすい方の本ではないかと思います。

今回のコードですが、教本の方でメインとなるファイルの mascot.cpp を最低限の構成に組み替えてみました。
内容的には前回の内容「Hello World!!」をmascot.cpp に適用してみただけのものです。

注釈としては、40行目からのところで、教本では領域外に出して非表示状態にしてある親窓を見える位置に置きなおしたのと、初期設定データの取り込みに始まる準備処理をごっそり削り落としました。

MainWindow=CreateWindowEx(0, MainWndClassName, MainWndClassName, WS_OVERLAPPEDWINDOW, 0, 0, 800, 600, NULL, NULL, Instance, NULL);
ShowWindow(MainWindow, SW_SHOW);

「猫でもわかるプログラミング」の 「イントロダクション」のコードの形に近くなりました。

あと引っ掛かった点は、制作メモ.txtにも書いてますが、

[引っ掛かったところ]
WNDCLASS の登録のところで、構造体のメンバlpszClassNameがデフォルトだと
(LPCWSTR)型を求めてくるのだが、キャストで対処するとタイトルバーの文字が化ける。

(引用)
プロジェクトのプロパティで「構成」が「Unicode文字セットを使用する」とか書いてあると思うんだけど
「マルチバイト文字セットを使用する」とする。
http://yuxx.net/1081/computer/programming/win32-sdk

にあるように、コード系を変えてあげると文字化けは回避できる

ソースコード[v02.lzh]

WindowsSDK 備忘録 その一

まんがタイムきららMAXで連載中の「ステラのまほう」を読んでて、そういえば最近趣味で書いたりするWindowsSDKのスクリプトも全然作っていないなーと思ったので備忘録をつけてみることにしました。

最初は”Hello World!!”を画面に出すいつものあれが、VisualStudioExpress2012 (マイクロソフトのサイトで無料で配ってる)で出来るかの確認をします。Windows7のマシンにインストールして起動し、Win32プロジェクトを新規作成、そのまま完了。すでにコードが準備されているのでちょっと追加と書き換えをして期待通りに動くか確認してみました。

Win32Project1.cppのコールバック関数に、

	PAINTSTRUCT ps;
	HDC hdc;
	char *szStr = "最初の一歩";

あと、


	case WM_PAINT:
		hdc = BeginPaint(hWnd, &ps);
		// TODO: 描画コードをここに追加してください...
		TextOutA(hdc, 10, 10, (LPCSTR)szStr, strlen(szStr));
		EndPaint(hWnd, &ps);
		break;

それと、少し戻って


hWnd = CreateWindowEx(WS_EX_OVERLAPPEDWINDOW, szWindowClass, szWindowClass, WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT, 800, 600, NULL, NULL, hInstance, NULL);

拡張型で窓を作るようにしてみました。で、出来たらビルド。動きましたね。

ソースコード[v01.lzh]

備忘録(DTP)

最近チェックした文書。

雑誌広告デジタル送稿推進協議会
http://www.3djma.jp/doc/20121001_MPDF_Guide.pdf

検索して引っ掛かったモノクロPDFの入稿手順書に目を通しただけですが、サイトのトップページからたどれば、カラーデータの入稿手順書なんかも閲覧できたりするようですね。

トレンドを決定する力のある新聞社や雑誌社のルールを知っておくのは悪いことでは無いような気がしたので書類に目を通してみました。

モノクロ入稿ルールを読んだ限りでは、やっぱり「とにかくデータがこけそうな設定は全部はずしておくように」と書いてあるように読みとれました。

自分で作ったデータをチェックする時に、ここの手順書に書いてあることで適用できるものに関しては、突き合わせてみてみるのもいいかと思いました。

P.S
Illstrator に配置するPhotoshopの画像は、今じゃ、PSDを推奨してるんですね。
EPSじゃないんだ(´・ω・`)

P.S 2
全部アウトライン化してPDFにしちゃうからデータセンター側にとっては都合がいいものだけど…入稿後に修正事項が見つかった場合の事考えると、通信線での入稿手段があることが前提でないと納品する側にとってはバイク便で再入稿するしか差し替えする手段がないからタイムスケジュールがきつい場合とってもシビアなルールのような気が…(;´Д`)

アルディーノ

Hellow World!!

とおんなじ感じのLED一個点滅させる最初の組み込みプログラムを実践してみました。独立した電源で動くのを見てるとなお楽しいです。(*´д`*)アハァ