このダイアログボックスを表示するには、ブロックダイアグラムでライブラリ関数呼び出しノードを右クリックし、ショートカットメニューから構成を選択します。

このダイアログボックスを使用して、オブジェクトに関するライブラリ、関数、パラメータ、戻り値、および、共有ライブラリの呼び出しに関する呼び出し規約を指定します。このダイアログボックスでOKボタンをクリックすると、LabVIEWではブロックダイアグラムにあるオブジェクトが更新されます。オブジェクトには端子の正しい個数が表示されたり端子に正しいデータタイプが設定され、このダイアログボックスの設定内容を反映します。

ライブラリ関数呼び出しノードを使用して、テキストベースのプログラム言語で書かれたコードを呼び出せます。 ActiveX オブジェクトを含む共有ライブラリを呼び出したい場合は、 Property NodeInvoke Nodeとともに Automation Open 関数を使用します。

このダイアログボックスには以下のコンポーネントが含まれています。

オプション 説明
機能 関数タブを使用して、ライブラリ関数呼び出しノードを構成します。

このタブには以下のコンポーネントがあります。

  • ライブラリ名またはパス

    呼び出すライブラリの名前またはパスを指定します。ライブラリの指定とパスの指定は同じことではなく、どちらを使用するかによってVIとアプリケーションを配布または移動したときの結果が異なります。共有ライブラリを名前で指定するかパスで指定するかは、共有ライブラリのディスク上の場所を指定するを参照して決定してください。

    リファレンスがプラットフォームに依存しないよう、ファイル拡張子にはワイルドカード (*) を使用します。C++コンパイラを使用する場合、ライブラリの関数の名前がマングル処理と呼ばれるプロセスによって変更され、プラットフォームに依存する形式になります。C++コンパイラでのマングル処理と呼ばれるプロセスにより、エクスポートされた関数名にプラットフォーム依存が発生することを避けるため、ヘッダファイルで、C++コンパイラ関数エクスポート指令でextern "C"{}を使用してください。

  • ダイアグラム上でパスを指定する

    ブロックダイアグラムでライブラリ名またはパスを入力するかどうかを決定します。このチェックボックスをオンにすると、パス入力パス出力がノードに対してコネクタペーンの入力および出力端子として表示されます。チェックボックスをオンにすると、ライブラリ名またはパス制御器で参照されるライブラリは使用されなくなります。 ヒント パス入力入力を使用して、以前参照されたライブラリをメモリからアンロードできます。空または無効パスをパス入力入力に配線して、ノードによって以前参照されたライブラリをメモリからアンロードします。

  • 機能名

    呼び出す関数の名前を指定します。 メモ ライブラリを参照すると、関数名制御器にそのライブラリで検出された関数名が表示されます。(macOS) 関数名制御器が空の場合、関数名のリストを表示するには、nmユーティリティをインストールする必要があります。nmユーティリティは、macOSの標準開発環境であるXcodeでインストールされます。XcodeはMac App Storeから無料でダウンロードできます。

  • スレッド

    ライブラリ関数呼び出しノードがVIによって現在実行されているスレッドからユーザインタフェーススレッドに切り替えるか、または現在実行中のスレッドを続行するかどうかを制御します。デフォルト値はUIスレッドで実行です。

    • UIスレッドで実行

      ライブラリ関数呼び出しノードの実行を、現在のスレッドではなくユーザインタフェーススレッドに切り替えるよう指定します。ダイアグラムでパスを指定によって動的にロードされたLabVIEWで作成された共有ライブラリのUIスレッドでノードを実行すると、LabVIEWがフリーズする可能性があります。

    • どんなスレッドでも走る

      ライブラリ関数呼び出しノードの実行がVIを実行中の現在のスレッドで続行することを指定します。複数のスレッドが関数を同時に呼び出せるようにする必要があります。 メモ LabVIEWで作成された共有ライブラリのすべての呼び出しでは、任意のスレッドで実行を指定する必要があります。LabVIEWで作成された共有ライブラリを使用してライブラリ関数呼び出しノードを構成して、UIスレッドで実行を構成すると、LabVIEWがフリーズして、コンピュータを再起動する必要がある場合があります。

  • 招集規約

    関数の呼び出し規約を指定します。デフォルトはCです。

    • 標準コール(WINAPI)-。

      オブジェクトが__stdcallの呼び出し規約を使用するかどうかを制御します。

    • C-

      オブジェクトが__cdeclの呼び出し規約を使用するかどうかを制御します。

  • 機能プロトタイプ

    関数のCプロトタイプを表示します。これは読み取り専用表示です。

パラメータ

ライブラリ関数呼び出しノードの現在のパラメータをリストします。パラメータリストの右側にある以下のボタンを使用してパラメータリストを構成できます。return typeは削除できない必須パラメータです。

  • パラメータ

    ライブラリ関数呼び出しノードの現在のパラメータをリストします。パラメータリストの右側にある以下のボタンを使用してパラメータリストを構成できます。return typeは削除できない必須パラメータです。

    • パラメータを追加する

      パラメータリストで選択したパラメータの下にパラメータを追加します。

    • 選択したパラメータを削除する。

      選択されたパラメータをパラメータリストから削除します。

    • 選択したパラメータを1つ上に移動する。

      関数プロトタイプのパラメータの順序を変更するパラメータリストで選択したパラメータを1つ上のレベルに移動します。

    • 選択したパラメータを下に移動する。

      関数プロトタイプのパラメータの順序を変更するパラメータリストで選択されたパラメータを1つ下のレベルに移動します。

  • 現在のパラメータ

    選択されたパラメータの設定を構成できます。

    • 名前

      パラメータ名を指定します。

    • タイプ

      パラメータのデータタイプを指定します。

      • Numeric-Numericデータ型の使用を指定する
        • データタイプ

          タイプ制御器で選択するデータの正確なタイプを指定します。

          メモ 符号付きポインタサイズ整数または符号なしポインタサイズ整数の数値データタイプを使用する場合、ライブラリ関数呼び出しノードは特定のオペレーティングシステムに適合し、実行後に適切なサイズのデータをライブラリ関数に返します。64ビットプラットフォームでは、LabVIEWはこれらの数値データタイプを64ビット整数タイプに変換します。32ビットプラットフォームでは、LabVIEWはこれらの数値データタイプを32ビット整数タイプに変換します。
        • パス

          値と値へのポインタのどちらを渡すかを指定します。

      • Array-Arrayデータ型を使用することを指定する
        • データタイプ

          タイプ制御器で選択するデータの正確なタイプを指定します。

          メモ 符号付きポインタサイズ整数または符号なしポインタサイズ整数の数値データタイプを使用する場合、ライブラリ関数呼び出しノードは特定のオペレーティングシステムに適合し、実行後に適切なサイズのデータをライブラリ関数に返します。64ビットプラットフォームでは、LabVIEWはこれらの数値データタイプを64ビット整数タイプに変換します。32ビットプラットフォームでは、LabVIEWはこれらの数値データタイプを32ビット整数タイプに変換します。
        • 寸法

          パラメータの次元を指定します。

        • 配列形式

          使用する配列形式を指定します。

        • 最小サイズ-

          1D配列の最小サイズを示し、適切なサイズのメモリ量を割り当てます。数値を入力できます。パラメータリストで整数パラメータを構成する場合は、プルダウンメニューからパラメータを選択できます。デフォルトはなしです。このオプションは、配列データポインタにのみ使用できます。

          最小サイズより小さい文字列を渡すと、LabVIEWは文字列のサイズを最小に拡大します。最小サイズよりも大きい文字列を渡す場合、文字列はより大きいサイズを保持します。最小サイズよりも小さい配列に渡す場合、LabVIEWは配列を最小サイズに拡張します。最小サイズよりも大きい配列に渡す場合、配列はより大きいサイズを保持します。
      • String -、Stringデータ 型を使用することを指定する。
        • 文字列フォーマット-使用する文字列フォーマットを指定する
        • 最小サイズ

          1D配列の最小サイズを示し、適切なサイズのメモリ量を割り当てます。数値を入力できます。パラメータリストで整数パラメータを構成する場合は、プルダウンメニューからパラメータを選択できます。デフォルトはなしです。このオプションは、配列データポインタにのみ使用できます。

      • Waveform-Waveformデータ・タイプを使用することを指定する。―データタイププルダウンメニューで、正確な数値データタイプを指定する必要があります。
        • データタイプ

          タイプ制御器で選択するデータの正確なタイプを指定します。

        • Dimensions-

          パラメータの次元を指定します。

          パラメータが単一波形の場合、 Dimensions に 0 を指定。パラメータがデジタル波形の「配列」の場合は次元を1に指定します。1次元よりも大きい波形の配列はサポートされていません。
      • Digital Waveform-デジタル波形データ・タイプの使用を指定する
        • Dimensions-

          パラメータの次元を指定します。

          パラメータが単一のデジタル波形の場合、 Dimensions に 0 を指定する。パラメータがデジタル波形の配列の場合は次元を1に指定します。1次元よりも大きいデジタル波形の配列はサポートされていません。
      • Digital Data-デジタル・データ型を使用することを指定する
        • Dimensions-

          パラメータの次元を指定します。

          パラメータがデジタルデータの配列の場合、 Dimensions に 1 を指定する。それ以外の場合は、次元を0に指定します。1次元よりも大きいデジタルデータの配列はサポートされていません。
      • ActiveX -、ActiveXデータ型を使用することを指定します。
        • データタイプ

          タイプ制御器で選択するデータの正確なタイプを指定します。

      • Adapt to Type -「Adapt to Type」データ型を使用することを指定する
        • データ形式- タイプ コントロールで選択したデータの形式を指定する
          • Allow Resize-

            ライブラリがパラメータのサイズ変更を許可するかどうかを指定します。場合によっては、サイズ変更を許可しないことでメモリで別のコピーの作成を回避できます。

            LabVIEWは、 定数 チェックボックスにチェックマークがある場合、定数パラメータのサイズを変更できないため、このオプションを無効にします。
            メモ このオプションは、データ形式プルダウンメニューからデータへのインタフェースを選択した場合のみ使用できます。
      • インスタンス・データ・ポインタ-インスタンス・データ・ポインタ・データ型を使用することを指定するインスタンスデータポインタは、ユーザ自身による判断で使用する可能性のあるポインタのサイズ割り当てを参照します。また、この割り当てはコールバックタブ上の各コールバック関数にも渡されます。
    • コンスタント

      パラメータが定数であるかを示します。

  • 機能プロトタイプ

    関数のCプロトタイプを表示します。これは読み取り専用表示です。

コールバック

コールバックタブでは、定義済みの時間で呼び出す関数を指定します。関数は、構成しているライブラリ関数呼び出しノードの特定のインスタンスに基づいて、DLLまたは共有ライブラリのデータの初期化、更新、クリーンアップができるようにします。各呼び出しは、関数が構成されているライブラリ関数呼び出しノードのインスタンスデータポインタに渡されます。

メモ コールバックタブで、ライブラリ関数にコールバック関数をパラメータとして渡すよう設定することはできません。ライブラリ関数呼び出しノードは、コールバック関数をパラメータとして必要とするライブラリ関数を直接呼び出せませんが、ラッパーライブラリを作成して呼び出しに実装することは可能です。

このタブには以下のコンポーネントがあります。

  • リザーブ

    各ノードおよび再入可能VIのデータスペースインスタンスに対して予約時に呼び出す関数を指定します。

  • アンリザーブ

    各ノードおよび再入可能VIのデータスペースインスタンスに対して予約解除時に呼び出す関数を指定します。予約解除コールバックを使用すると、情報の保存や解析、およびクリーンアップ操作の実行が可能です。

  • 中止

    DLLの呼び出しが進行中にVIを中断する場合に呼び出す関数を指定します。ライブラリ関数呼び出しノードがUIスレッドで実行するように設定されている場合、中断の処理は呼び出されません。中断のコールバックを使用すると、情報の保存や解析、およびクリーンアップ操作の実行が可能です。

  • これらの手順のプロトタイプ

    ユーザ定義のプロシージャコールのCプロトタイプを表示します。各関数は、InstanceDataPtrパラメータを渡します。このパラメータで、ライブラリ関数呼び出しノードで呼び出す任意の関数に渡すことができる、ノードのインスタンスデータの初期化およびアクセスを行うことができます。プロトタイプは、ポインタ型で保持されるすべての型 (数値、または共有ライブラリやDLLによって割り当てられたストラクチャへの実際のポインタなど) に型変換できます。 これは読み取り専用表示です。

  • 機能プロトタイプ

    関数のCプロトタイプを表示します。これは読み取り専用表示です。

エラーチェック

エラーチェックタブで、ライブラリ関数呼び出しノードのエラーチェックレベルを指定します。

このタブには以下のコンポーネントがあります。

  • エラーチェック・レベル

    次のオプションがあります。

    • 最大

      ライブラリ関数呼び出しノードのエラーチェックの最大レベルを有効にします。最大レベルでは、デフォルトレベルのエラーチェック機能のほかに、共有ライブラリまたはDLLで呼び出される関数が、指定された文字列または配列パラメータ用紙をに割り当てられた領域以上に書き込んだときに、ライブラリ関数呼び出しノードが警告を返します。 メモ エラーチェックタブで最大を選択すると、実行速度が低下し、ライブラリ関数呼び出しノードのメモリ使用量が増加します。したがって、ライブラリ関数呼び出しノードの構成をデバッグする場合のみ、最大オプションを選択することを推奨します。

    • デフォルト

      ライブラリ関数呼び出しノードに対してエラーチェックのデフォルトレベルを有効にします。エラーチェックのデフォルトレベルでは、呼び出された共有ライブラリまたはDLLが実行中に発生する未処理の例外から回復することをLabVIEWに許可します。また、このエラーチェックレベルでは、関数タブで選択した呼び出し規約が、共有ライブラリまたはDLLで呼び出している関数の呼び出し規約と一致しない場合、ライブラリ関数呼び出しノードがエラーを返します。

    • 無効

      ライブラリ関数呼び出しノードのエラーチェックを無効にします。ライブラリ関数呼び出しノードのエラーチェックを無効にすると、ライブラリ関数呼び出しノードの実行速度が向上します。ただし、エラーによっては、LabVIEWが予期せずシャットダウンする原因となります。エラーチェックを無効にする前に、ライブラリ関数呼び出しノードが参照する関数によって未処理の例外が発生しないことを確認してください。

  • 機能プロトタイプ

    関数のCプロトタイプを表示します。これは読み取り専用表示です。

関連情報

LabVIEWで共有ライブラリを呼び出す

ライブラリ関数呼び出しノードを構成する

共有ライブラリのデバックおよび呼び出しを行う

ライブラリ関数呼び出しノード

LabVIEW Manager Functions