MZPlatformユーザー会

フォーラムへの返信

10件の投稿を表示中 - 221 - 230件目 (全793件中)
  • 投稿者
    投稿
  • 返信先: エクセル連携導入(派遣管理)-2.mzax #6745
    MZPlatformユーザー会
    キーマスター

    お問い合わせありがとうございます。
    ご指摘の通り、このアプリケーションの中ではイベント番号を必要としない「SQL文を実行する(String)」でも正常に動作します。
    イベント番号を指定するメソッドを使用している理由としては、一つのアプリケーションの中で実行されるSQL文に区別をつけたい、今後改修、発展したときに必要になる場合があるなどが挙げられます。

    実行されるSQLはUpdate文とSelect文ですが、Update文は実行後、処理完了イベントが発生し、イベント内包データとして「更新された行数」が取得できます。
    Select文は実行後データ生成イベントが発生し、テーブルデータを取得できます。
    [サブルーチン(ID17)]が呼び出されると[データベースアクセス]のメソッドも呼び出されUpdate文もSelect文も両方実行されていますが、Update文ではデータ生成イベントは発生しません。

    仮に、SQLが両方Select文だった場合は、データ生成イベントに繋げてイベント番号1を設定した処理、イベント番号2を設定した処理、それぞれに呼び出されます。
    イベント番号を指定しない「SQL文を実行する(String)」の実行による発生イベントは「イベント番号0」という扱いになります。イベント番号を設定していない、または他のイベント番号に加えて番号0を設定している処理が起動されます。

    まとめますと、SQL文の種類により発生するイベントが違うことが、データ生成イベントの接続処理が呼び出されない大きな理由ですが、仮にデータ生成イベントが発生するSQL文がイベント番号2とともに実行されても、イベント番号1の処理は呼び出されません。イベント番号を指定しないSQL文が実行されても、イベント番号1の処理は呼び出されません。

    実は、メソッド「イベント番号を指定してSQL文を実行する(String,int)」を使用した場合でも、イベント番号を設定していない接続処理は起動されます。したがって、このアプリケーション内ではイベント番号は必須ではないのですが、実用のアプリケーションでは[データベースアクセス]で複数のSQL文を実行することが多く、チュートリアルという性質上、このような記載にしております。

    以上、ご不明な点がございましたら、どうぞ再度ご連絡ください。
    よろしくお願い申し上げます。

    MZPlatformユーザー会
    キーマスター

    お問い合わせありがとうございます。
    メソッド「時間軸の表示期間を設定する(int,PFGanttChartTimeUnit)」の第2引数には、時間の単位を設定します。この単位オブジェクトは固定値では設定できませんが、[ガントチャート]から取得できるようになっています。
    第2引数の設定で例えば、『取得方法:メソッド戻り値、コンポーネント:ガントチャート、メソッド/値:単位(時)を取得する』とします。

    ご不明な点がございましたら、再度ご連絡ください。よろしくお願いいたします。

    MZPlatformユーザー会
    キーマスター

    お問い合せありがとうございます。
    一定間隔で文字等が変化する処理には、[タイマー]を使うことになるかと思います。
    タイマーの実行間隔は属性情報のDelayとinitialDelay(起動後最初に実行されるまでの間隔)で設定します。既定の間隔は1000msになっています。

    タイマーが実行されるごとに[任意精度整数(BigInteger)格納変数]の値を1ずつ増やし、[剰余(%)]で2で除算した余りの値を取得すれば、0か1が交互に取得できます。
    [イベント生成]コンポーネントはイベント番号と共にイベントを発生させることができるので、上記の値をイベント番号として処理を行うことができます。

    動作確認のため、簡単なサンプルファイルを作りましたので、どうぞご覧ください。
    ラベルの背景色も設定していますが、取得方法:固定値でRGB値または13色の色名「white, lightGray, gray, darkGray, black, red, pink, orange, yellow, green, cyan, blue, magenta」で指定が可能です。

    ご不明な点がございましたら、再度ご連絡ください。よろしくお願い申し上げます。

    MZPlatformユーザー会
    キーマスター

    接続可のOpenJDKから接続不可のOpenJDKにアップデートされたことで、TLS1.0と1.1が無効化され、デフォルトがTLS1.3になったことが原因のようです。なお、MySQL8.0.16以降では問題が起きない可能性がありますので、そちらのアップデートもご検討いただけますでしょうか。

    参考:リリースノート 8u292-b10 (GA), April 20th 2021
    https://mail.openjdk.org/pipermail/jdk8u-dev/2021-April/013680.html
    上記リンク先の「JDK-8256490: Disable TLS 1.0 and 1.1」

    MZアプリ側からMySQLサーバ側へのJDBC接続時のTLSバージョンの不整合が起きるようで、明示的にTLS1.2を使用した接続を指定することで回避したという事例をネット検索で発見しました。ただし、TLS1.2には脆弱性が含まれますので、ご使用の場合はご注意ください。

    回避方法は、JDBC接続で下記のように指定している部分を、
    jdbc:mysql://localhost/mzdb
    下記のように変更するとうまくいくと思います。
    jdbc:mysql://localhost/mzdb?enabledTLSProtocols=TLSv1.2

    スマート製造ツールキットのサンプルアプリであれば、mzapp.iniの下記の記述
    db.db=jdbc:mysql://localhost/mzdb
    を、下記のように変更すれば回避できます。
    db.db=jdbc:mysql://localhost/mzdb?enabledTLSProtocols=TLSv1.2

    MZPlatformユーザー会
    キーマスター

    お問い合わせありがとうございます。
    画像の入力には[画像ファイル入力]コンポーネント、表示には[イメージビューワー]コンポーネントを使用します。
    チュートリアルでは[ファイル選択]コンポーネントをファイル名を選べるように使っていますが、[画像ファイル入力]の引数に直接ファイル名を設定することも可能です。

    例えば、[ボタン]を押したら特定の画像を入力、表示する場合には、以下の2つの処理で表示できます。
    ➀[ボタン]---アクションイベント---[画像ファイル入力]
    <メソッド>ファイル名を指定して画像を読み込む(String)
    <引数>取得方法:固定値 メソッド/値:ファイルまでのパス(例:C:\MZPlatform\3.6_64\AP_DATA\Tutorial.mZ_logo.gif)
    ➁[画像ファイル入力]---データ生成イベント---[イメージビューワー]
    <メソッド>イメージデータを設定する(image)
    <引数>取得方法:イベント内包 メソッド/値:イベント対象データ

    利用できる画像ファイルの形式は、 BMP,WBMP,GIF,JPEG,PNGとなっています。

    以上、ご不明な点がございましたら、どうぞ再度ご連絡ください。
    よろしくお願い申し上げます。

    返信先: システム情報の件 #6723
    MZPlatformユーザー会
    キーマスター

    お問い合せありがとうございます。
    [システム情報]コンポーネントのメソッド「getSystemProperty(String)」をお試しいただいているかと思います。ユーザー名取得の引数は「user.name」で結構です。
    WindowsOSのローカルで作られるユーザー名は2種類あり「ローカルアカウントのユーザー名」と「ユーザーネームのフルネーム」のうち、上記メソッドでは「・・・ユーザー名」の方が取得されます。
    しかし、「ユーザーネームのフルネーム」を設定済みだった場合、コントロールパネルからの変更だけではフルネームのみ変更されるようです。
    外部のサイトになりますが、こちらが参考になるかと思います。
    https://jp.ext.hp.com/techdevice/windows10sc/26/  (日本HP Tech&DeviceTV 『Windows 10 のユーザー名を変更するには?アカウントの種類とそれぞれの変更方法を紹介』)

    [システム情報]の「ホスト名を取得する()」ですと、MZを実行しているマシーンのデバイス名が取得されます。

    以上ご検討いただき、解決されない場合は、お手数ですが再度ご連絡ください。
    どうぞよろしくお願い申し上げます。

    返信先: Farmata通信 #6720
    MZPlatformユーザー会
    キーマスター

    お問い合わせありがとうございます。
    設定ファイルは、アプリケーション自体は変更せず設定ファイルの中身を書き換えることで動きの変更をすることができ、Javaプログラム以外でも広く使われていますが、決まった書式はあります。

    名前(キー)=値という書式になっていて、[セクション名]を指定する場合もあります。どんな「キー名」、「セクション名」を指定するかは決まりはなく、アプリケーションことに独自に決められています。

    IotEdgeApp.mzaxの[設定ファイル管理]複合コンポーネントが呼び出されている箇所では、キー名を指定して設定データを取得する処理を行っています。MZPlatformにはキーと値をペアにして格納できる[マップ格納変数]があり、キー名による値の取得・設定を行うことができます。

    以上、ご不明な点がございましたら、どうぞ再度ご連絡ください。よろしくお願いいたします。

    返信先: Farmata通信 #6717
    MZPlatformユーザー会
    キーマスター

    お問い合わせありがとうございます。

    mzapp.iniはテキスト形式の設定ファイルです。「メモ帳」等で開いて中身を確認することができます。
    特に『MZ講習資料IOTエッジ編』P64にあるように、アプリから状態認識結果のデータをデータベースに格納していますが、そのデータベースの接続情報をこのファイルで設定しています。
    また、入出力テーブルとして表示されている起動時のPINモードも、このファイルで設定されています。

    返信先: Farmata通信 #6713
    MZPlatformユーザー会
    キーマスター

    お問い合わせありがとうございます。

    『MZ講習資料IoTエッジ編.pdf』P49にあるとおり、現在のバージョンではメニューには出てきませんが標準で含まれています。

    追加方法が判りにくくご不便をお掛けいたしますが、新規に追加する方法は以下の2つがあります。
    1.コンポーネント追加の際、[クラス指定…]を選び、入力窓に「jp.go.aist.dmrc.platform.beans.io.PFFirmataConnector」と入力します。
    2.アプリケーションビルダー―を二つ起動します。片方で[Firmata通信]が使われているアプリケーションをロードし、編集画面左側にある接続元コンポーネントの[Firmata通信]をコピーします。もう一つのビルダー編集画面で右クリック>貼り付けをします。

    ご不明な点がございましたら、どうぞ再度ご連絡ください。
    よろしくお願い申し上げます。

    返信先: MZで検索した項目の履歴をとりたい #6707
    MZPlatformユーザー会
    キーマスター

    お問い合わせありがとうございます。
    [コンボボックス]は項目選択後に特に処理を行わなければ、選択位置の移動はありませんが、
    アプリケーション実行中に選択位置/選択項目ラベルを記憶しておきたいというのであれば[文字列格納変数]に設定しておくことが考えられます。

    コンボボックスに要素を追加し、それを選択したいということであれば、[リスト格納変数]に一旦追加すると便利です。

    動作確認のため簡単なサンプルファイルを添付いたしますので、ご参考になれば幸いです。

10件の投稿を表示中 - 221 - 230件目 (全793件中)