0

Windows フォーム (c#) でクロム ネイティブ アプリケーションを使用しています。クロムで拡張機能を有効にすると、開いていました。アプリケーションexeをクリックしたときだけ開くように管理できますか? どうすればそれができますか?これはC#コードです

  private static string OpenStandardStreamIn()
    {
    //// We need to read first 4 bytes for length information
    Stream stdin = Console.OpenStandardInput();
    int length = 0;
    byte[] bytes = new byte[4];
    stdin.Read(bytes, 0, 4);
    length = System.BitConverter.ToInt32(bytes, 0);

    string input = "";
    for (int i = 0; i < length;i++ )    
    {
    input += (char)stdin.ReadByte();
    }

    return input;  
    }

    private static void OpenStandardStreamOut(string stringData)
    {
    //// We need to send the 4 btyes of length information
    string msgdata = "{\"text\":\"" + stringData + "\"}";
    int DataLength = stringData.Length;
    Stream stdout = Console.OpenStandardOutput();
    stdout.WriteByte((byte)((DataLength >> 0) & 0xFF));
    stdout.WriteByte((byte)((DataLength >> 8) & 0xFF));
    stdout.WriteByte((byte)((DataLength >> 16) & 0xFF));
    stdout.WriteByte((byte)((DataLength >> 24) & 0xFF));
    //Available total length : 4,294,967,295 ( FF FF FF FF )

    Console.Write(msgdata);
    }

background.JS コード

  var host_name = "com.example.native";
    var port = null;

    connectToNative();
    function connectToNative()
    {
    console.log('Connecting to native host: ' + host_name);
    port = chrome.runtime.connectNative(host_name);
    port.onMessage.addListener(onNativeMessage);
    port.onDisconnect.addListener(onDisconnected);
    sendNativeMessage("test");

}

function sendNativeMessage(msg) {
message = {"text" : msg};
console.log('Sending message to native app: ' + JSON.stringify(message));
port.postMessage(message);
console.log('Sent message to native app: ' + msg);
}

function onNativeMessage(message) {
console.log('recieved message from native app: ' + JSON.stringify(msg));
}

function onDisconnected() {
    console.log(chrome.runtime.lastError);
console.log('disconnected from native app.');
port = null;
}

Chrome 拡張機能をアプリケーションに接続するための Menifest ファイル

{
  "name": "com.example.native",
  "description": "Native support for Chrome Extension",
  "path": "NativeApp.exe",
  "type": "stdio",
  "allowed_origins": [
    "chrome-extension://ajfkjfmkedgcgdckdkmppfblonpeench/"
  ]
}  
4

1 に答える 1

2

Native Host アプリのポイントは、必要に応じて Chrome で開くことです。そのインスタンスを手動で開くと、Chrome に接続されません。

擬似コードでは、ネイティブ アプリに次のロジックを実装できます。

if( /* opened by Chrome */ ){
  // Do not show UI
  // Listen for command to show UI
  // Communicate with Chrome
} else {
  if( /* there is an open instance of the app */) {
    // Message that instance to show UI
    // Terminate
  } else {
    // Show error, terminate
  }
}

この質問は興味深いかもしれません。

于 2014-08-28T09:25:05.620 に答える