TVITEMW 構造体 (commctrl.h)
ツリー ビュー項目の属性を指定または受信します。 この構造体は TV_ITEM 構造体と同じですが、現在の名前付け規則に従うように名前が変更されました。 新しいアプリケーションでは、この構造を使用する必要があります。
構文
typedef struct tagTVITEMW {
UINT mask;
HTREEITEM hItem;
UINT state;
UINT stateMask;
LPWSTR pszText;
int cchTextMax;
int iImage;
int iSelectedImage;
int cChildren;
LPARAM lParam;
} TVITEMW, *LPTVITEMW;
メンバーズ
mask
型: UINT
有効なデータを含む他の構造体メンバーを示すフラグの配列。 この構造体を TVM_GETITEM メッセージと共に使用すると、mask メンバーは取得する項目属性を示します。 TVM_SETITEM メッセージと共に使用する場合、マスク は設定する属性を示します。 このメンバーには、次の値のうち 1 つ以上を指定できます。
価値 | 意味 |
---|---|
|
cChildren メンバーは有効です。 |
|
ツリー ビュー コントロールは、指定された情報を保持し、再度要求しません。 このフラグは、TVN_GETDISPINFO 通知を処理する場合にのみ有効です。 |
|
hItem メンバーが有効です。 |
|
iImage メンバーは有効です。 |
|
lParam メンバーは有効です。 |
|
iSelectedImage メンバーは有効です。 |
|
状態 および stateMask メンバーが有効です。 |
|
pszText および cchTextMax メンバーが有効です。 |
hItem
型: HTREEITEM
アイテムへのハンドル。
state
型: UINT
項目の状態を示すビット フラグとイメージ リスト インデックスのセット。 項目の状態を設定する場合、stateMask メンバーは、このメンバーの有効なビットを示します。 アイテムの状態を取得するときに、このメンバーは、stateMask メンバーに示されているビットの現在の状態を返します。
このメンバーのビット 0 から 7 には、項目状態フラグが含まれています。 使用可能な項目の状態フラグの一覧については、「Tree-View コントロール項目の状態を参照してください。
オーバーレイイメージは、アイテムのアイコン画像の上に重ね合わされます。 このメンバーのビット 8 から 11 は、1 から 1 から始まるオーバーレイ 画像インデックスを指定します。 これらのビットが 0 の場合、項目にはオーバーレイ イメージがありません。 これらのビットを分離するには、TVIS_OVERLAYMASK マスクを使用します。 このメンバーのオーバーレイ イメージ インデックスを設定するには、INDEXTOOVERLAYMASK マクロを使用します。 イメージ リストのオーバーレイ イメージは、ImageList_SetOverlayImage 関数で設定されます。
状態イメージは、アプリケーション定義の状態を示す項目のアイコンの横に表示されます。 TVM_SETIMAGELIST メッセージを送信して、状態イメージの一覧を指定します。 項目の状態イメージを設定するには、TVITEM 構造体の stateMask メンバーに TVIS_STATEIMAGEMASK 値を含めます。 構造体の 状態 メンバーのビット 12 から 15 は、描画するイメージの状態イメージ リストのインデックスを指定します。
状態イメージ のインデックスを設定するには、INDEXTOSTATEIMAGEMASK
stateMask
型: UINT
有効なメンバー
pszText
型: LPTSTR
構造体で項目属性が指定されている場合、項目テキストを含む null で終わる文字列へのポインター。 このメンバーがLPSTR_TEXTCALLBACK値の場合、親ウィンドウは名前の格納を担当します。 この場合、ツリー ビュー コントロールは、表示、並べ替え、または編集にアイテム テキストが必要な場合は、親ウィンドウに TVN_GETDISPINFO 通知コードを送信し、項目のテキストが変更されたときに TVN_SETDISPINFO 通知コードを送信します。 構造体が項目属性を受け取っている場合、このメンバーは項目テキストを受け取るバッファーのアドレスです。 ツリー ビュー コントロールでは、任意の長さの文字列を項目テキストとして格納できますが、最初の 260 文字のみが表示されることに注意してください。
cchTextMax
型: int
pszText メンバーが指すバッファーのサイズ (文字数)。 この構造体を使用して項目属性を設定する場合、このメンバーは無視されます。
iImage
型: int
項目が選択されていない状態のときに使用するアイコン イメージのツリー ビュー コントロールのイメージ リスト内のインデックス。 このメンバーがI_IMAGECALLBACK値の場合、親ウィンドウはインデックスの格納を担当します。 この場合、ツリー ビュー コントロールは、イメージを表示する必要があるときにインデックスを取得する TVN_GETDISPINFO 通知コードを親に送信します。
iSelectedImage
型: int
項目が選択された状態のときに使用するアイコン イメージのツリー ビュー コントロールのイメージ リスト内のインデックス。 このメンバーがI_IMAGECALLBACK値の場合、親ウィンドウはインデックスの格納を担当します。 この場合、ツリー ビュー コントロールは、イメージを表示する必要があるときにインデックスを取得する TVN_GETDISPINFO 通知コードを親に送信します。
cChildren
型: int
項目に関連付けられている子項目があるかどうかを示すフラグ。 このメンバーには、次のいずれかの値を指定できます。
価値 | 意味 |
---|---|
|
項目に子項目がありません。 |
|
項目には、1 つ以上の子項目があります。 |
|
親ウィンドウは、項目に子項目があるかどうかを追跡します。 この場合、ツリー ビュー コントロールで項目を表示する必要がある場合、コントロールは親に TVN_GETDISPINFO 通知コードを送信して、項目に子項目があるかどうかを判断します。
ツリー ビュー コントロールに TVS_HASBUTTONS スタイルがある場合、このメンバーを使用して、子項目の存在を示すボタンを表示するかどうかを決定します。 このメンバーを使用すると、項目に子項目が挿入されていない場合でも、コントロールにボタンの表示を強制できます。 これにより、項目が表示または展開されている場合にのみ子項目を挿入することで、コントロールのメモリ使用量を最小限に抑えながらボタンを表示できます。 |
|
バージョン 6.0内部使用を目的としています。アプリケーションでの使用は推奨されません。 ツリー ビュー コントロールは、項目に子項目があるかどうかを自動的に決定します。
メモ このフラグは、今後のバージョンの Comctl32.dllではサポートされない可能性があります。 また、このフラグは commctrl.h では定義されていません。 フラグを使用するには、アプリケーションのソース ファイルに次の定義を追加します。
|
lParam
型: LPARAM
項目に関連付ける値。
備考
手記
commctrl.h ヘッダーは、UNICODE プリプロセッサ定数の定義に基づいて、この関数の ANSI または Unicode バージョンを自動的に選択するエイリアスとして TVITEM を定義します。 エンコードに依存しないエイリアスをエンコードに依存しないコードと組み合わせて使用すると、コンパイルエラーやランタイム エラーが発生する不一致が発生する可能性があります。 詳細については、「関数プロトタイプの 規則」を参照してください。
必要条件
要件 | 価値 |
---|---|
サポートされる最小クライアント | Windows Vista [デスクトップ アプリのみ] |
サポートされる最小サーバー | Windows Server 2003 [デスクトップ アプリのみ] |
ヘッダー | commctrl.h |