с помощью tabcapture chrome extansion api

avatar
Denis Dombrovski
8 августа 2021 в 17:37
184
0
0

Я пытаюсь записать экран пользователя, чтобы создать gif, попытка использовать chrome API captureTab безуспешно, Я попытался запустить API из сценария содержимого, который не был определен, затем из iframe с моим кодом расширения и получил исключение Unchecked runtime.lastError: Ошибка при запуске захвата вкладки Я использую версию манифеста 3

прочитав документацию, API захвата работает только в сценариях переднего плана, поэтому, возможно, я этого не понял,

мой манифест

{
  "short_name": "***",
  "name": "***",
  "manifest_version": 3,
  "version": "2.1.0",
  "icons": {
    "16": "screenShotIcon.png",
    "48": "screenShotIcon.png",
    "128": "screenShotIcon.png"
  },

  "key": "***",
  "action": {
    "default_title": "***",
    "default_icon": {
      "19": "screenShotIcon.png",
      "38": "screenShotIcon.png"
    }
  },
  "permissions": ["storage", "identity", "scripting", "activeTab"],
  "optional_permissions": ["tabCapture", "downloads"],
  "web_accessible_resources": [
    {
      "resources": [
        "gif.html",
        "gif.js",

      ],
      "matches": ["<all_urls>"]
    }
  ],
  "options_page": "options.html",
  "background": {
    "service_worker": "background.js"
  },
  "commands": {
    "_execute_action": {
      "suggested_key": {
        "default": "Ctrl+Shift+Q",
        "mac": "MacCtrl+Shift+Q"
      }
    },
    "default-action": {
      "suggested_key": {
        "default": "Ctrl+Q",
        "mac": "Command+Q"
      },
      "description": "default operation "
    }
  },
  "externally_connectable": {
    "matches": ["***"]
  },
  "content_scripts": [
    {
      "matches": ["<all_urls>"],
      "js": ["content.js"]
    }
  ]
}

также код запуска iframe

iFrame = document.getElementById(popupGifName);
  if (!iFrame) {
    iFrame = document.createElement("iframe");
    iFrame.id = popupGifName;
    iFrame.style.position = "fixed";
    iFrame.style.height = "100%";
    iFrame.style.width = "100%";
    iFrame.style.border = "none";
    iFrame.style.top = "0px";
    iFrame.style.right = "0px";
    iFrame.style.zIndex = "9000000000000000000";
    document.body.appendChild(iFrame);
  }
  iFrame.src = chrome.runtime.getURL("gif.html");

и, наконец, начало захвата

const getStream = async () => {
    const active = await getActiveTab();

    chrome.tabCapture.capture(
      {
        video: true,
        audio: true,
        videoConstraints: {
          mandatory: {
            minWidth: 16,
            minHeight: 9,
            maxWidth: 854,
            maxHeight: 480,
            maxFrameRate: 60, // Note: Frame rate is variable (0 <= x <= 60).
          },
        },
      },
      (stream) => {
        console.log(stream);
      }
    );
  };

  return (
    <div>
      <button onClick={() => getStream()}>start rerecord</button>
      <video
        ref={videoRef}
        width="100px"
        height="100px"
        style={{ position: "absolute" }}
      />
    </div>
  );
}

Я пробовал все, от запуска API из фона до всплывающего окна, но ничего не работает

спасибо за помощь

Источник

Ответы (0)