本格アプリの作り方
【開発環境】
os:Windows 10 (64ビット)
IDE(統合開発環境):VisualStudio 2017
言語;VB
【参考書】
株式会社秀和システム「作って覚えるVisualBasic2017」
著者:萩原 博之/宮崎 昭世
【目的】
簡易家計簿アプリを通して本格的なアプリの作り方を学ぶ事。どのようにプログラミングを進めていくか?を考える。
●アプリを作る目的
→パソコンで家計簿を作る
●家計簿に必要な機能をまとめる
→1.日々の買い物・金額などのデータを入力する機能
→2.入力データの確認や、合計を表示する機能
→3.入力データを保存する機能
→4.入力データを合計する機能
→5.間違えたデータを修正・削除する機能
→6.買い物を月ごとに集計・計算する機能
●処理
機能に実行するプログラムを考える。コントロールの選定などやプログラムなど
【画面デザイン】
こんな感じにする。画面は登録画面とメイン画面の2画面を用意する。
data:image/s3,"s3://crabby-images/1655c/1655c185c8b0885c46d67214201802bc9763df44" alt=""
■メイン画面の設定
data:image/s3,"s3://crabby-images/19a94/19a94fb974940e225575bc45d56ab595af2169c1" alt=""
コントロールの配置
①Formコントロール
Textプロパティ=家計簿
②MenuStripコントロール
(Name)プロパティ=mainMenu
③DataGridViewコントロール
(Name)プロパティ=dgy
④Buttonコントロール
(Name)プロパティ=buttonAdd
Textプロパティ=追加
⑤Buttonコントロール
(Name)プロパティ=buttonChange
Textプロパティ=変更
⑥Buttonコントロール
(Name)プロパティ=buttonDelete
Textプロパティ=削除
⑦Buttonコントロール
(Name)プロパティ=buttonEnd
Textプロパティ=終了
■登録画面
登録用のフォームを作成する
①プロジェクトの[追加]から「Windowファーム」を選択する
data:image/s3,"s3://crabby-images/bc10a/bc10a123c6a9dbb8f8d8e43975eb2898eb8268ee" alt=""
②[新しい項目の追加]ダイアログボックスから、「Windowファーム」を選択し、
名前の項目に「ItemForm」と記入し、「追加ボタン」を押す
data:image/s3,"s3://crabby-images/c59e1/c59e122edc9768c88e9c527417470068e1bceec7" alt=""
③「ItemForm」フォームに各コントロールを配置して登録画面を作る
data:image/s3,"s3://crabby-images/b7f79/b7f79f54135e973e6ac38e4a413bcadc17562314" alt=""
[ItemFormのコントロール設定]
①Formコントロール
Textプロパティ=登録
②MonthCalenderコントロール
(Name)プロパティ=MonCalender
③Labelコントロール
Textプロパティ=分類
④Labelコントロール
Textプロパティ=品名
⑤Labelコントロール
Textプロパティ=金額
⑥Labelコントロール
Textプロパティ=備考
⑦ComboBoxコントロール
(Name)プロパティ=cmbCategory
DropDownStyleプロパティ=DropDownList
⑧TextBoxコントロール
(Name)プロパティ=txtItem
⑨MaskedTextBoxコントロール
(Name)プロパティ=mtxtMoney
Maskプロパティ=999999(6桁)
TextAlign=Right
⑩TextBoxコントロール
(Name)プロパティ=txtRemarks
⑪Buttonコントロール
(Name)プロパティ=buttonOK
Textプロパティ=登録
DialogResultプロパティ=OK
⑫Buttonコントロール
(Name)プロパティ=buttonCancel
Textプロパティ=キャンセル
DialogResultプロパティ=Cancel
【メインのメニュー項目の作成】
・ファイル
data:image/s3,"s3://crabby-images/131c9/131c938f7c1f1c02fb09a1d0dc89c99ccf0f9bfc" alt=""
・編集
data:image/s3,"s3://crabby-images/794e9/794e9770e7db14bb1725dd53d11b93606a15341d" alt=""
・表示
data:image/s3,"s3://crabby-images/73c1c/73c1ce12afac0625e8efca5c76ef67a6e62329a1" alt=""
・ヘルプ
data:image/s3,"s3://crabby-images/471b9/471b9052d34c1227098223aac2b5ff43d0f26368" alt=""
※区切り線は[ここへ入力]の横の↓をクリックし、リストから[Separator]を選ぶ
【データセット】
登録画面で追加したデータをメインの一覧画面に反映させたい場合に、このデータを格納する領域が必要となる。そのため、VBでは複数のデータを扱うデータセットという仕組みがある。
ここでは型付きデータセットを使う。
①ソリューションエクスプローラーにある家計簿を右クリックし、[追加]-[新しい項目]を選択する
data:image/s3,"s3://crabby-images/65226/65226115978dbbfe628c981f558e7d6ce2ee48bb" alt=""
②「テンプレート」-[データセット]を選択し、名前の欄に「MoneyDataSet.xsd」と記入し、「追加」ボタンを押す
data:image/s3,"s3://crabby-images/d46f9/d46f9b80a02ae6b58446a50156578c0a21df4d72" alt=""
③ツールボックスから[DataTabel]コントロールをドラック&ドロップして画面に貼る
data:image/s3,"s3://crabby-images/f5665/f56659709aa85400812ae40e40b24dde78db1695" alt=""
④[DataTabel]コントロールを右クリックし、[追加]-[列]をクリックし、下図のように作成する
data:image/s3,"s3://crabby-images/4703c/4703cdc91727a06057a9eb12bf8faf0584b4a558" alt=""
■それぞれのColumn(列)コントロール
data:image/s3,"s3://crabby-images/597b4/597b4ba47f6a16634d0dfb7849c6df7343f77c06" alt=""
①Data Tableコントロール
Nameプロパティ=moneyDataTable
②Columnコントロール
Nameプロパティ=日付
DataTypeプロパティ=System.DateTime
③Columnコントロール
Nameプロパティ=分類
DataTypeプロパティ=System.String
④Columnコントロール
Nameプロパティ=品名
DataTypeプロパティ=System.String
⑤Columnコントロール
Nameプロパティ=金額
DataTypeプロパティ=System.In32
⑥Columnコントロール
Nameプロパティ=備考
DataTypeプロパティ=System.String
⑤MoneyDataSetのビルド
data:image/s3,"s3://crabby-images/e9930/e993054f7473bc27510ce8684ec927976e861947" alt=""
⑥ビルドの確認
data:image/s3,"s3://crabby-images/adaa8/adaa82c49b017f03edce72175d120f2d1a1618fe" alt=""
【DataGridViewコントロールにデータセットを結びつける】
1)一覧画面のDataGridViewコントロールのスマートタグをクリックする
data:image/s3,"s3://crabby-images/7749f/7749f2c4e09e00330b07a441961bd6f463a5f276" alt=""
2)DataGridViewタスクから[meneyDataTable]を選択する。
data:image/s3,"s3://crabby-images/af3b5/af3b5d9dacb28f05439247a02e7f09f4ddb315e5" alt=""
3)列が表示される
data:image/s3,"s3://crabby-images/b871d/b871da675ee1a9c9e40c51856b92fc4070c6692b" alt=""
※コメント投稿者のブログIDはブログ作成者のみに通知されます