・MFCの開発環境をそろえよう
・MFCをスタティックリンクしたときに出るエラー
・関数追加時に出るエラー
・Windows XPスタイルの外観にする
・CStringの基本1 文字列の連結と追加
・ATL/MFC共有版のCStringについて
・CStringと三項演算子の問題
・DDXの基本1
・DDXの基本2
・DDX変数に複数コントロールを割り当てる
・DDX変数を配列にする
・ダイアログの色変更
・ボタンの基本
・チェックボックスの基本
・プッシュボタンのようなチェックボックス
・チェックボックスの色変更
・エディットボックスの基本
・エディットボックスの色変更
・コンボボックスの基本
・コンボボックスに初期データを入れる
・コンボボックスの色変更
・拡張コンボボックス
・リストボックスの基本
・リストボックスの色変更
・チェックリストボックスを作る
・ラジオボタンの基本
・ラジオボタンの色変更
・スタティックテキストの内容を動的に変更する
・スタティックテキストに複数行入力する
・スタティックテキストの文字色変更
・リストコントロールの基本1
・リストコントロールの基本2
・リストコントロールの一行全体を選択する
・リストコントロールを単一行選択にする
・フォーカスが移ったときも選択状態を維持する
・アイテムにユーザデータを付加する
・アイテムにアイコンをつける
・アイテムに状態イメージをつける
・ヘッダ項目にアイコンをつける
・ツリーコントロールの基本
・タブコントロールの基本1
・タブコントロールの基本2
・タブコントロールをXPスタイルにする
・スライダコントロールの基本1
・スライダコントロールの基本2
・スピンコントロールの基本
・プログレスバーの基本
・日時指定コントロールの基本
・月間予定表コントロールの基本
・月間予定表のプロパティと色変更
・IPアドレスコントロールの基本
・IPアドレスコントロールの操作
・ピクチャーコントロールの基本
・アニメーションコントロールの基本
・CTimeとCTimeSpan
・CTimeの引数について
・ダイアログにメニューをつける
・ダイアログにポップアップメニューをつける
・ダイアログにステータスバーをつける
・ステータスバーに文字列を表示する
・プロパティシートの基本1
・プロパティシートの基本2
・ファイル選択ダイアログ
・フォント選択ダイアログ
・色選択ダイアログ
・ファイル入出力の基本
・テキストファイルの入出力
・ファイルの検索、列挙1
・ファイルの検索、列挙2
・MFCソケット通信の基本 (クライアント編)
・MFCソケット通信の基本 (サーバ編)
・MFC非同期ソケット (クライアント編1)
・MFC非同期ソケット (クライアント編2)
・MFC非同期ソケット(サーバ編1)
・MFC非同期ソケット(サーバ編2)
・デバイスコンテキストの基本
・文字列の描画
・ペンを使った描画
・ブラシを使った描画1
・ブラシを使った描画2
・FTPクライアントを作る1
・FTPクライアントを作る2
・FTPクライアントを作る3
・FTPクライアントを作る4
・FTPクライアントを作る5
・ドキュメント・ビューの基本
・エディットビューの基本
・リストビューの基本
・ツリービューの基本
・フォームビューの基本
・ダイアログバーの基本
・ダイアログにダイアログバーをつける
トップページへ戻る
|
|
FTPクライアントを作る3
今回はディレクトリ操作関連を実装していきます。まずはカレントディレクトリの移動部分です。"1つ上に移動"ボタン"と"ディレクトリ移動"ボタン押下時のイベントハンドラです。
// "1つ上に移動"ボタン押下
void CFtpClientDlg::OnBnClickedBtnDirparent()
{
ChangeDirectory(_T(".."));
}
// "ディレクトリ移動"ボタン押下
void CFtpClientDlg::OnBnClickedBtnDirchange()
{
int sel = 0;
CString name;
if ((sel = m_xcList.GetCurSel()) != LB_ERR)
{
m_xcList.GetText(sel, name);
if (name.Left(3) == _T("[D]")) ChangeDirectory(name.Mid(3));
}
}
|
両方とも次に説明する自作のChangeDirectory()関数を呼び出しています。親ディレクトリを指定する場合は、ディレクトリ名を".."とします。では、ディレクトリの移動関数です。
// ディレクトリ移動
void CFtpClientDlg::ChangeDirectory(CString dirName)
{
int err = 0;
if (!err) if (!m_ftpConP) err = 1;
// カレントディレクトリ変更
if (!err) if (!m_ftpConP->SetCurrentDirectory(dirName)) err = 1;
/*if (!err) */Refresh();
}
|
カレントディレクトリの変更はCFtpConnection::SetCurrentDirectory()関数を使います。相対パス、絶対パスのどちらを指定することもできます。
| BOOL CFtpConnection::SetCurrentDirectory(LPCTSTR pstrDirName); |
| 説明: |
カレントディレクトリの変更 |
| 引数: |
pstrDirName:ディレクトリ名(相対パスまたは絶対パス) |
| 戻り値: |
正常終了した場合は0以外、それ以外の場合は0 |
次はディレクトリの作成です。まずは名前入力用のダイアログを作っておきましょう。

ダイアログにはCDialogを基本クラスとしたダイアログクラスを追加しておきます。今回はクラス名をCDialogNameとしました。エディットボックスにはDDX変数を追加し、名前の取得関数GetName()を作っておきます。
class CDialogName : public CDialog
{
DECLARE_DYNAMIC(CDialogName)
public:
CDialogName(CWnd* pParent = NULL); // 標準コンストラクタ
virtual ~CDialogName();
CString GetName(){return m_xvEditName;}
// ダイアログ データ
enum { IDD = IDD_DIALOG_NAME };
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV サポート
DECLARE_MESSAGE_MAP()
private:
CString m_xvEditName;
};
|
では、"ディレクトリ作成"ボタン押下時のイベントハンドラです。
// "ディレクトリ作成"ボタン押下
void CFtpClientDlg::OnBnClickedBtnMakedir()
{
CDialogName nameDlg;
CString str;
int err = 0;
if (!err) if (!m_ftpConP) err = 1;
// ディレクトリ名入力
if (!err) if (nameDlg.DoModal() != IDOK) err = 1;
// ディレクトリ作成
if (!err) if (!m_ftpConP->CreateDirectory(nameDlg.GetName())) err = 1;
if (!err) Refresh();
// メッセージ表示
str = (err) ? _T("ディレクトリ作成に失敗しました。")
: _T("ディレクトリを作成しました。");
MessageBox(str);
}
|
まずは作成した名前入力ダイアログをCDialog::DoModal()関数で表示します。OKが押されたら作成したGetName()関数でディレクトリ名を取得し、ディレクトリを作成します。ディレクトリの作成にはCFtpConnection::CreateDirectory()関数を使います。
| BOOL CFtpConnection::CreateDirectory(LPCTSTR pstrDirName); |
| 説明: |
ディレクトリの作成 |
| 引数: |
pstrDirName:ディレクトリ名(相対パスまたは絶対パス) |
| 戻り値: |
正常終了した場合は0以外、それ以外の場合は0 |
では次はディレクトリの削除です。
// "ディレクトリ削除"ボタン押下
void CFtpClientDlg::OnBnClickedBtnRemovedir()
{
CString dirName, str;
int sel = 0;
int err = 0;
if (!err) if (!m_ftpConP) err = 1;
// ディレクトリ名取得
if (!err) if ((sel = m_xcList.GetCurSel()) == LB_ERR) err = 1;
if (!err)
{
m_xcList.GetText(sel, dirName);
if (dirName.Left(3) != _T("[D]")) err = 1;
}
// ディレクトリ削除
if (!err) if (!m_ftpConP->RemoveDirectory(dirName.Mid(3))) err = 1;
if (!err) Refresh();
// メッセージ表示
str = (err) ? _T("ディレクトリ削除に失敗しました。")
: _T("ディレクトリを削除しました。");
MessageBox(str);
}
|
リストボックスで現在選択されているものを取得し、ディレクトリであれば削除します。ディレクトリの削除にはCFtpConnection::RemoveDirectory()関数を使います。
| BOOL CFtpConnection::RemoveDirectory(LPCTSTR pstrDirName); |
| 説明: |
ディレクトリの削除 |
| 引数: |
pstrDirName:ディレクトリ名(相対パスまたは絶対パス) |
| 戻り値: |
正常終了した場合は0以外、それ以外の場合は0 |
では、今回はここで一区切りにしましょう。次回はいよいよファイルのアップロード、ダウンロードなどのファイル操作関連を実装していきます。
|
|