{"id":1571,"date":"2024-10-08T13:54:26","date_gmt":"2024-10-08T16:54:26","guid":{"rendered":"https:\/\/thiagorossi.com.br\/blog\/?p=1571"},"modified":"2025-11-27T12:19:25","modified_gmt":"2025-11-27T15:19:25","slug":"gerenciamento-de-janelas","status":"publish","type":"post","link":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/","title":{"rendered":"Gerenciamento de Janelas"},"content":{"rendered":"<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">Tempo de leitura: <\/span> <span class=\"rt-time\"> 4<\/span> <span class=\"rt-label rt-postfix\">minutos<\/span><\/span>\n<p class=\"has-medium-font-size wp-block-paragraph\">O <strong>Gerenciamento de Janelas<\/strong> em Progressive Web Apps (PWAs) \u00e9 crucial para que o aplicativo instalado (o modo <em>standalone<\/em>) se integre e se comporte de forma esperada no sistema operacional (SO). Embora o controle total de janelas seja tipicamente restrito a aplica\u00e7\u00f5es nativas, as APIs web oferecem um conjunto crescente de funcionalidades para manipular o cont\u00eainer visual e melhorar a UX.<\/p>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\">1. \ud83d\udccf Informa\u00e7\u00f5es B\u00e1sicas da Janela e Tela<\/h2>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">O objeto <strong><code>window<\/code><\/strong> (para a viewport do PWA) e o objeto <strong><code>screen<\/code><\/strong> (para o monitor f\u00edsico) fornecem informa\u00e7\u00f5es vitais para o layout e adapta\u00e7\u00e3o do aplicativo.<\/p>\n\n\n\n<figure class=\"wp-block-table has-medium-font-size\"><table class=\"has-fixed-layout\"><thead><tr><td><strong>Objeto<\/strong><\/td><td><strong>Propriedade<\/strong><\/td><td><strong>Descri\u00e7\u00e3o<\/strong><\/td><\/tr><\/thead><tbody><tr><td><strong><code>window<\/code><\/strong><\/td><td><code>innerWidth<\/code> \/ <code>innerHeight<\/code><\/td><td>Dimens\u00f5es da <strong>\u00e1rea de conte\u00fado<\/strong> vis\u00edvel do PWA (viewport).<\/td><\/tr><tr><td><strong><code>screen<\/code><\/strong><\/td><td><code>width<\/code> \/ <code>height<\/code><\/td><td>Resolu\u00e7\u00e3o total do <strong>monitor<\/strong> ou tela do dispositivo.<\/td><\/tr><tr><td><strong><code>window<\/code><\/strong><\/td><td><code>devicePixelRatio<\/code><\/td><td>Rela\u00e7\u00e3o entre pixels f\u00edsicos e pixels CSS (essencial para renderiza\u00e7\u00e3o em telas Retina\/HDPI).<\/td><\/tr><tr><td><strong><code>document<\/code><\/strong><\/td><td><code>title<\/code><\/td><td>O texto exibido na barra de t\u00edtulo da janela do PWA (no modo Desktop).<\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">JavaScript<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>console.log(`Resolu\u00e7\u00e3o da tela: ${screen.width}x${screen.height}`);\nconsole.log(`Viewport: ${window.innerWidth}x${window.innerHeight}`);\ndocument.title = 'Meu PWA: Nova Tarefa';\n<\/code><\/pre>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\">2. \ud83d\uddb1\ufe0f Movimenta\u00e7\u00e3o e Redimensionamento (Limita\u00e7\u00f5es)<\/h2>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Em PWAs instaladas em <strong>Desktop<\/strong> (Chrome\/Edge), o navegador gerencia o redimensionamento e a movimenta\u00e7\u00e3o da janela. O JavaScript da PWA tem controle limitado sobre essas a\u00e7\u00f5es por raz\u00f5es de seguran\u00e7a.<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li class=\"has-medium-font-size\"><strong>Mover\/Redimensionar (Suporte Limitado):<\/strong> O m\u00e9todo <code>window.open()<\/code> pode receber par\u00e2metros de altura (<code>height<\/code>) e largura (<code>width<\/code>), mas isso geralmente abre uma <strong>nova aba<\/strong> ou uma <strong>nova janela pop-up<\/strong> (n\u00e3o a janela do PWA em si).<\/li>\n\n\n\n<li class=\"has-medium-font-size\"><strong>APIs Nativas:<\/strong> Para controle total do cont\u00eainer da janela, como no Electron, a PWA requer empacotamento em uma solu\u00e7\u00e3o que fa\u00e7a a ponte entre a API web e a API nativa do SO.<\/li>\n<\/ul>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\">3. \ud83d\udcd1 Simulando Modo com Guias (Tabs)<\/h2>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Como PWAs instaladas n\u00e3o oferecem guias de navega\u00e7\u00e3o nativas como um navegador completo, a funcionalidade de m\u00faltiplas visualiza\u00e7\u00f5es ou p\u00e1ginas deve ser <strong>simulada dentro da pr\u00f3pria interface do aplicativo<\/strong>.<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li class=\"has-medium-font-size\"><strong>Abordagem:<\/strong> Utilize frameworks de componentes (como Materialize, Bootstrap, React) para implementar componentes de <strong>abas<\/strong> ou <strong>carrossel<\/strong> de conte\u00fado.<\/li>\n\n\n\n<li class=\"has-medium-font-size\"><strong>Mecanismo:<\/strong> Ao clicar em uma aba, o JavaScript manipula o DOM para mostrar\/ocultar o conte\u00fado correspondente, mantendo a navega\u00e7\u00e3o r\u00e1pida e dentro de uma \u00fanica p\u00e1gina (SPA &#8211; Single Page Application).<\/li>\n<\/ul>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">HTML<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;ul class=\"tabs\"&gt;\n  &lt;li class=\"tab\"&gt;&lt;a href=\"#dashboard\"&gt;Dashboard&lt;\/a&gt;&lt;\/li&gt;\n  &lt;li class=\"tab\"&gt;&lt;a href=\"#settings\"&gt;Configura\u00e7\u00f5es&lt;\/a&gt;&lt;\/li&gt; \n&lt;\/ul&gt;\n\n&lt;div id=\"dashboard\"&gt;Conte\u00fado do Dashboard&lt;\/div&gt;\n&lt;div id=\"settings\"&gt;Conte\u00fado das Configura\u00e7\u00f5es&lt;\/div&gt;\n<\/code><\/pre>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\">4. \ud83d\udd12 Wake Lock de Tela (Screen Wake Lock API)<\/h2>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Esta API permite que o PWA solicite ao sistema operacional que <strong>impe\u00e7a a tela de apagar ou o dispositivo de entrar em modo de suspens\u00e3o<\/strong> por inatividade. \u00c9 essencial para tarefas que exigem que a tela permane\u00e7a acesa (ex: mapas, cron\u00f4metros, exibi\u00e7\u00e3o de QR codes).<\/p>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">Implementa\u00e7\u00e3o<\/h3>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">O <em>lock<\/em> deve ser solicitado e, crucialmente, <strong>liberado<\/strong> quando n\u00e3o for mais necess\u00e1rio, para preservar a bateria do dispositivo.<\/p>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">JavaScript<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>let wakeLock = null;\n\nconst requestWakeLock = async () =&gt; {\n  try {\n    \/\/ Solicita o wake lock de tela\n    wakeLock = await navigator.wakeLock.request('screen');\n    console.log('Wake Lock ativo.');\n    \n    \/\/ O lock \u00e9 liberado automaticamente quando a aba \u00e9 minimizada\n    \/\/ ou o dispositivo \u00e9 bloqueado.\n\n    \/\/ Para liberar manualmente\n    \/\/ wakeLock.release(); \n  } catch (err) {\n    console.error(`Erro no Wake Lock: ${err.name}, ${err.message}`);\n  }\n};\n\n\/\/ Ativa o lock quando uma funcionalidade cr\u00edtica for iniciada\nrequestWakeLock();\n<\/code><\/pre>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p class=\"has-medium-font-size wp-block-paragraph\"><strong>Nota:<\/strong> O <em>wake lock<\/em> \u00e9 uma API sens\u00edvel ao contexto. Se o usu\u00e1rio mudar de aba ou a PWA for minimizada, o sistema operacional pode liberar o <em>lock<\/em> automaticamente. Voc\u00ea deve re-solicit\u00e1-lo se a PWA for reativada.<\/p>\n<\/blockquote>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\">5. \ud83d\uddfa\ufe0f Navega\u00e7\u00e3o Externa<\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li class=\"has-medium-font-size\"><strong>Navega\u00e7\u00e3o Interna:<\/strong> Para links que pertencem ao <code>scope<\/code> do PWA, use o <strong>Hist\u00f3rico de API<\/strong> ou <em>routing<\/em> para evitar recarregar a p\u00e1gina.<\/li>\n\n\n\n<li class=\"has-medium-font-size\"><strong>Navega\u00e7\u00e3o Externa:<\/strong> Para URLs que <strong>n\u00e3o<\/strong> pertencem ao <code>scope<\/code> do PWA (ex: links para outro site), use o <code>window.location.href<\/code> ou <code>window.open()<\/code>. O navegador abrir\u00e1 uma nova aba ou janela normal fora do cont\u00eainer do seu PWA.<\/li>\n<\/ul>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">JavaScript<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\/\/ Navega para fora do escopo do PWA\nwindow.location.href = 'https:\/\/www.site-externo.com';\n<\/code><\/pre>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">\u2705 Conclus\u00e3o Gerenciamento de Janelas<\/h2>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\"><strong>Gerenciamento de Janelas<\/strong>: O controle da janela em PWAs \u00e9 um conjunto de t\u00e9cnicas que inclui o uso do <strong><code>document.title<\/code><\/strong> e das propriedades <strong><code>window<\/code><\/strong> para adaptar o layout, a simula\u00e7\u00e3o de guias com frameworks de interface, e a integra\u00e7\u00e3o com APIs de sistema como o <strong>Screen Wake Lock<\/strong>. Ao adotar essas pr\u00e1ticas, o PWA oferece uma experi\u00eancia instalada que maximiza a imers\u00e3o e minimiza as distra\u00e7\u00f5es, aproximando-se da fluidez de um aplicativo nativo.<\/p>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Toda jornada tem um in\u00edcio, e o in\u00edcio para se tornar um desenvolvedor web \u00e9 dominar as seguintes tecnologias, que voc\u00ea encontra aqui mesmo:<\/p>\n\n\n\n<div class=\"wp-block-columns is-layout-flex wp-container-core-columns-is-layout-8f761849 wp-block-columns-is-layout-flex\">\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"\/category\/html\"><img loading=\"lazy\" decoding=\"async\" width=\"758\" height=\"426\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/html.webp\" alt=\"HTML\" class=\"wp-image-600\" srcset=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/html.webp 758w, https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/html-300x169.webp 300w\" sizes=\"auto, (max-width: 758px) 100vw, 758px\" \/><\/a><figcaption class=\"wp-element-caption\">HTML<\/figcaption><\/figure>\n<\/div>\n\n\n\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"\/category\/css\"><img loading=\"lazy\" decoding=\"async\" width=\"758\" height=\"426\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/Capa-Artigos-Linux.webp\" alt=\"CSS\" class=\"wp-image-702\" srcset=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/Capa-Artigos-Linux.webp 758w, https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/Capa-Artigos-Linux-300x169.webp 300w\" sizes=\"auto, (max-width: 758px) 100vw, 758px\" \/><\/a><figcaption class=\"wp-element-caption\">CSS<\/figcaption><\/figure>\n<\/div>\n\n\n\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"\/category\/javascript\"><img loading=\"lazy\" decoding=\"async\" width=\"758\" height=\"426\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/javascript.webp\" alt=\"Javascript\" class=\"wp-image-804\" srcset=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/javascript.webp 758w, https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/javascript-300x169.webp 300w\" sizes=\"auto, (max-width: 758px) 100vw, 758px\" \/><\/a><figcaption class=\"wp-element-caption\">JavaScript<\/figcaption><\/figure>\n<\/div>\n<\/div>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">E se voc\u00ea gosta do nosso conte\u00fado, n\u00e3o deixe de contribuir adquirindo os servi\u00e7os e produtos dos nossos apoiadores e empresas que somos associados:<\/p>\n\n\n\n<div class=\"wp-block-columns is-layout-flex wp-container-core-columns-is-layout-8f761849 wp-block-columns-is-layout-flex\">\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/hostinger.com.br\/?REFERRALCODE=1THIAGO62\"><img loading=\"lazy\" decoding=\"async\" width=\"300\" height=\"250\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/03\/hostinger.png\" alt=\"Hospedagem Hostinger\" class=\"wp-image-92\"\/><\/a><\/figure>\n<\/div>\n\n\n\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/amzn.to\/3SNDYlc\"><img loading=\"lazy\" decoding=\"async\" width=\"300\" height=\"250\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/ofertas-amazon.webp\" alt=\"Ofertas Amazon\" class=\"wp-image-1308\"\/><\/a><\/figure>\n<\/div>\n\n\n\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/amzn.to\/3SNKmt0\"><img loading=\"lazy\" decoding=\"async\" width=\"300\" height=\"250\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/amazonprime.webp\" alt=\"Amazon Prime\" class=\"wp-image-1307\"\/><\/a><\/figure>\n<\/div>\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">Tempo de leitura: <\/span> <span class=\"rt-time\"> 4<\/span> <span class=\"rt-label rt-postfix\">minutos<\/span><\/span>O Gerenciamento de Janelas em Progressive Web Apps (PWAs) \u00e9 crucial para que o aplicativo&#8230;<\/p>\n","protected":false},"author":1,"featured_media":1497,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[16],"tags":[],"class_list":["post-1571","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-pwa","wpcat-16-id"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.7 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Gerenciamento de Janelas - BLOG THIAGO ROSSI<\/title>\n<meta name=\"description\" content=\"Gerenciamento de Janelas: Neste artigo, exploraremos as diversas formas de manipular janelas em PWAs, desde mover e redimensionar at\u00e9 ...\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/\" \/>\n<meta property=\"og:locale\" content=\"pt_BR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Gerenciamento de Janelas - BLOG THIAGO ROSSI\" \/>\n<meta property=\"og:description\" content=\"Gerenciamento de Janelas: Neste artigo, exploraremos as diversas formas de manipular janelas em PWAs, desde mover e redimensionar at\u00e9 ...\" \/>\n<meta property=\"og:url\" content=\"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/\" \/>\n<meta property=\"og:site_name\" content=\"BLOG THIAGO ROSSI\" \/>\n<meta property=\"article:published_time\" content=\"2024-10-08T16:54:26+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-11-27T15:19:25+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/Capa-Artigos.webp\" \/>\n\t<meta property=\"og:image:width\" content=\"758\" \/>\n\t<meta property=\"og:image:height\" content=\"426\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/webp\" \/>\n<meta name=\"author\" content=\"Thiago Rossi\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"Thiago Rossi\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. tempo de leitura\" \/>\n\t<meta name=\"twitter:data2\" content=\"5 minutos\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/gerenciamento-de-janelas\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/gerenciamento-de-janelas\\\/\"},\"author\":{\"name\":\"Thiago Rossi\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#\\\/schema\\\/person\\\/5f28286948ec2afdeb2e044a2196cd87\"},\"headline\":\"Gerenciamento de Janelas\",\"datePublished\":\"2024-10-08T16:54:26+00:00\",\"dateModified\":\"2025-11-27T15:19:25+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/gerenciamento-de-janelas\\\/\"},\"wordCount\":687,\"publisher\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#organization\"},\"image\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/gerenciamento-de-janelas\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/08\\\/Capa-Artigos.webp\",\"articleSection\":[\"PWA\"],\"inLanguage\":\"pt-BR\"},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/gerenciamento-de-janelas\\\/\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/gerenciamento-de-janelas\\\/\",\"name\":\"Gerenciamento de Janelas - BLOG THIAGO ROSSI\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/gerenciamento-de-janelas\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/gerenciamento-de-janelas\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/08\\\/Capa-Artigos.webp\",\"datePublished\":\"2024-10-08T16:54:26+00:00\",\"dateModified\":\"2025-11-27T15:19:25+00:00\",\"description\":\"Gerenciamento de Janelas: Neste artigo, exploraremos as diversas formas de manipular janelas em PWAs, desde mover e redimensionar at\u00e9 ...\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/gerenciamento-de-janelas\\\/#breadcrumb\"},\"inLanguage\":\"pt-BR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/gerenciamento-de-janelas\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/gerenciamento-de-janelas\\\/#primaryimage\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/08\\\/Capa-Artigos.webp\",\"contentUrl\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/08\\\/Capa-Artigos.webp\",\"width\":758,\"height\":426,\"caption\":\"PWA\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/gerenciamento-de-janelas\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Gerenciamento de Janelas\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#website\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/\",\"name\":\"THIAGO ROSSI\",\"description\":\"Mais de 20 anos de experi\u00eancia no mercado de TI!\",\"publisher\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#organization\"},\"alternateName\":\"TR | CURSO WEB DEV\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"pt-BR\"},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#organization\",\"name\":\"THIAGO ROSSI\",\"alternateName\":\"TR | CURSO WEB DEV\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/04\\\/new-logo.webp\",\"contentUrl\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/04\\\/new-logo.webp\",\"width\":300,\"height\":300,\"caption\":\"THIAGO ROSSI\"},\"image\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\"},\"sameAs\":[\"https:\\\/\\\/linkedin.com\\\/in\\\/thiagox86\"]},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#\\\/schema\\\/person\\\/5f28286948ec2afdeb2e044a2196cd87\",\"name\":\"Thiago Rossi\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g\",\"url\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g\",\"contentUrl\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g\",\"caption\":\"Thiago Rossi\"},\"description\":\"Com mais de 20 anos de jornada na tecnologia, minha trajet\u00f3ria evoluiu do ensino t\u00e9cnico \u00e0 arquitetura de sistemas complexos. Hoje, foco minha expertise no desenvolvimento de solu\u00e7\u00f5es de Intelig\u00eancia Artificial nativa e an\u00e1lise de dados p\u00fablicos, utilizando o ecossistema PHP para transformar dados brutos em transpar\u00eancia e efici\u00eancia. Como autor e desenvolvedor, acredito na democratiza\u00e7\u00e3o do conhecimento. Essa vis\u00e3o resultou em uma biblioteca de mais de 530 artigos gratuitos, cobrindo desde a base do WebDev e Infraestrutura at\u00e9 os bastidores da ind\u00fastria de Jogos e IA. No universo de Game Design, sou autor do livro \\\"GDD \u2013 O Guia Definitivo\\\" e documento ativamente meus processos atrav\u00e9s de DevLogs, unindo rigor t\u00e9cnico e criatividade em projetos desenvolvidos com GDevelop 5. Meu compromisso \u00e9 conectar engenharia de ponta com as reais oportunidades do mercado de tecnologia.\",\"sameAs\":[\"https:\\\/\\\/thiagorossi.com.br\\\/blog\",\"https:\\\/\\\/instagram.com\\\/thiagorossix86\",\"https:\\\/\\\/linkedin.com\\\/in\\\/thiagox86\"],\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/author\\\/thiagorossi\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Gerenciamento de Janelas - BLOG THIAGO ROSSI","description":"Gerenciamento de Janelas: Neste artigo, exploraremos as diversas formas de manipular janelas em PWAs, desde mover e redimensionar at\u00e9 ...","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/","og_locale":"pt_BR","og_type":"article","og_title":"Gerenciamento de Janelas - BLOG THIAGO ROSSI","og_description":"Gerenciamento de Janelas: Neste artigo, exploraremos as diversas formas de manipular janelas em PWAs, desde mover e redimensionar at\u00e9 ...","og_url":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/","og_site_name":"BLOG THIAGO ROSSI","article_published_time":"2024-10-08T16:54:26+00:00","article_modified_time":"2025-11-27T15:19:25+00:00","og_image":[{"width":758,"height":426,"url":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/Capa-Artigos.webp","type":"image\/webp"}],"author":"Thiago Rossi","twitter_card":"summary_large_image","twitter_misc":{"Escrito por":"Thiago Rossi","Est. tempo de leitura":"5 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/#article","isPartOf":{"@id":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/"},"author":{"name":"Thiago Rossi","@id":"https:\/\/thiagorossi.com.br\/blog\/#\/schema\/person\/5f28286948ec2afdeb2e044a2196cd87"},"headline":"Gerenciamento de Janelas","datePublished":"2024-10-08T16:54:26+00:00","dateModified":"2025-11-27T15:19:25+00:00","mainEntityOfPage":{"@id":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/"},"wordCount":687,"publisher":{"@id":"https:\/\/thiagorossi.com.br\/blog\/#organization"},"image":{"@id":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/#primaryimage"},"thumbnailUrl":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/Capa-Artigos.webp","articleSection":["PWA"],"inLanguage":"pt-BR"},{"@type":"WebPage","@id":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/","url":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/","name":"Gerenciamento de Janelas - BLOG THIAGO ROSSI","isPartOf":{"@id":"https:\/\/thiagorossi.com.br\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/#primaryimage"},"image":{"@id":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/#primaryimage"},"thumbnailUrl":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/Capa-Artigos.webp","datePublished":"2024-10-08T16:54:26+00:00","dateModified":"2025-11-27T15:19:25+00:00","description":"Gerenciamento de Janelas: Neste artigo, exploraremos as diversas formas de manipular janelas em PWAs, desde mover e redimensionar at\u00e9 ...","breadcrumb":{"@id":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/#breadcrumb"},"inLanguage":"pt-BR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/"]}]},{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/#primaryimage","url":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/Capa-Artigos.webp","contentUrl":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/Capa-Artigos.webp","width":758,"height":426,"caption":"PWA"},{"@type":"BreadcrumbList","@id":"https:\/\/thiagorossi.com.br\/blog\/gerenciamento-de-janelas\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/thiagorossi.com.br\/blog\/"},{"@type":"ListItem","position":2,"name":"Gerenciamento de Janelas"}]},{"@type":"WebSite","@id":"https:\/\/thiagorossi.com.br\/blog\/#website","url":"https:\/\/thiagorossi.com.br\/blog\/","name":"THIAGO ROSSI","description":"Mais de 20 anos de experi\u00eancia no mercado de TI!","publisher":{"@id":"https:\/\/thiagorossi.com.br\/blog\/#organization"},"alternateName":"TR | CURSO WEB DEV","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/thiagorossi.com.br\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"pt-BR"},{"@type":"Organization","@id":"https:\/\/thiagorossi.com.br\/blog\/#organization","name":"THIAGO ROSSI","alternateName":"TR | CURSO WEB DEV","url":"https:\/\/thiagorossi.com.br\/blog\/","logo":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/thiagorossi.com.br\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/new-logo.webp","contentUrl":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/new-logo.webp","width":300,"height":300,"caption":"THIAGO ROSSI"},"image":{"@id":"https:\/\/thiagorossi.com.br\/blog\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/linkedin.com\/in\/thiagox86"]},{"@type":"Person","@id":"https:\/\/thiagorossi.com.br\/blog\/#\/schema\/person\/5f28286948ec2afdeb2e044a2196cd87","name":"Thiago Rossi","image":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/secure.gravatar.com\/avatar\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g","caption":"Thiago Rossi"},"description":"Com mais de 20 anos de jornada na tecnologia, minha trajet\u00f3ria evoluiu do ensino t\u00e9cnico \u00e0 arquitetura de sistemas complexos. Hoje, foco minha expertise no desenvolvimento de solu\u00e7\u00f5es de Intelig\u00eancia Artificial nativa e an\u00e1lise de dados p\u00fablicos, utilizando o ecossistema PHP para transformar dados brutos em transpar\u00eancia e efici\u00eancia. Como autor e desenvolvedor, acredito na democratiza\u00e7\u00e3o do conhecimento. Essa vis\u00e3o resultou em uma biblioteca de mais de 530 artigos gratuitos, cobrindo desde a base do WebDev e Infraestrutura at\u00e9 os bastidores da ind\u00fastria de Jogos e IA. No universo de Game Design, sou autor do livro \"GDD \u2013 O Guia Definitivo\" e documento ativamente meus processos atrav\u00e9s de DevLogs, unindo rigor t\u00e9cnico e criatividade em projetos desenvolvidos com GDevelop 5. Meu compromisso \u00e9 conectar engenharia de ponta com as reais oportunidades do mercado de tecnologia.","sameAs":["https:\/\/thiagorossi.com.br\/blog","https:\/\/instagram.com\/thiagorossix86","https:\/\/linkedin.com\/in\/thiagox86"],"url":"https:\/\/thiagorossi.com.br\/blog\/author\/thiagorossi\/"}]}},"_links":{"self":[{"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/posts\/1571","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/comments?post=1571"}],"version-history":[{"count":1,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/posts\/1571\/revisions"}],"predecessor-version":[{"id":5009,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/posts\/1571\/revisions\/5009"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/media\/1497"}],"wp:attachment":[{"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/media?parent=1571"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/categories?post=1571"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/tags?post=1571"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}