{"id":84,"date":"2008-09-29T09:01:29","date_gmt":"2008-09-29T12:01:29","guid":{"rendered":"https:\/\/devkico.itexto.com.br\/?p=84"},"modified":"2008-09-29T09:01:29","modified_gmt":"2008-09-29T12:01:29","slug":"gerando-arquivos-odf-com-java-anunciando-o-odfeasy","status":"publish","type":"post","link":"https:\/\/devkico.itexto.com.br\/?p=84","title":{"rendered":"Gerando arquivos ODF com Java: anunciando o ODFEasy"},"content":{"rendered":"<p>Semana passada, em um de nossos projetos, precisamos gerar alguns gr\u00e1ficos no Excel usando Java. N\u00e3o para nossa surpresa, o suporte a esta funcionalidade do formato Excel \u00e9 extremamente limitada para aqueles que trabalham com Java. Basicamente, vimos duas op\u00e7\u00f5es:<\/p>\n<ul>\n<li>Criar um modelo pr\u00e9-definido com um gr\u00e1fico j\u00e1 pr\u00e9-criado e, em seguida, simplesmente preencher algumas c\u00e9lulas do gr\u00e1fico em quest\u00e3o.<\/li>\n<li>Utilizar uma biblioteca como o JExcel, que permite acesso via COM ao Excel, permitindo assim automatizar sua execu\u00e7\u00e3o.<\/li>\n<\/ul>\n<p>Para o nosso caso, dado que nossos gr\u00e1ficos ser\u00e3o criados din\u00e2micamente, a primeira op\u00e7\u00e3o foi f\u00e1cilmente excluida. Isto porque o n\u00famero de s\u00e9ries de nossos gr\u00e1ficos poderia sofrer in\u00fameras varia\u00e7\u00f5es, isto sem mencionar do pr\u00f3prio tipo de gr\u00e1fico a ser gerado.<\/p>\n<p>A segunda, bem: ser\u00e1 que valeria a pena jogar fora a portabilidade que ganhamos com Java? E outra: gerar arquivos do Excel via automa\u00e7\u00e3o \u00e9 extremanete leeeeento.<\/p>\n<p>Sendo assim, optamos por adotar o formato ODF. Buscamos algumas bibliotecas e acabamos por optar pelo <a href=\"http:\/\/wiki.services.openoffice.org\/wiki\/ODFDOM\" target=\"_blank\">ODFDOM<\/a>. A primeira vista, pareceu ser a solu\u00e7\u00e3o ideal. Navegando r\u00e1pidamente pela estrutura de classes, vimos todos os componentes de que precis\u00e1vamos. J\u00e1 na hora de usar a API&#8230;<\/p>\n<p>As coisas nem de longe aparentavam ser t\u00e3o f\u00e1ceis assim. Na realidade, gerar arquivos ODF \u00e9 muito mais complicado do que haviamos imaginado. isto porque a biblitoeca ODFDOM \u00e9 fortemente focada no XML, e n\u00e3o no documento em si. Pela interface que possuimos com a biblioteca, o tempo inteiro acessamos n\u00f3s em um documento XML, o que, convenhamos, nem de longe \u00e9 a maneira mais simples de se visualizar o documento final que se visa criar via c\u00f3digo.<\/p>\n<p>(claro, sei que o projeto ainda est\u00e1 na vers\u00e3o 0.6.x, mas mesmo assim, para as nossas necessidades atuais, n\u00e3o \u00e9 suficiente).<\/p>\n<p>Como resultado, optamos por criar uma nova camada baseada no ODFDOM para a gera\u00e7\u00e3o de arquivos neste formato. Por enquanto, estamos chamando esta nova API de <strong>ODFEasy<\/strong>.\u00a0Esta possuir\u00e1 uma interface voltada mais para a gera\u00e7\u00e3o do documento em si. O c\u00f3digo gerado por esta biblioteca, acreditamos, ser\u00e1 muito mais simples de ser compreendido do que aquele que produzimos usando o ODFDOM.\u00a0<\/p>\n<p>(Acredito que a exist\u00eancia de uma API simplificada como a ODFEasy seja <strong>essencial <\/strong>para a ado\u00e7\u00e3o bem sucedida do formato ODF. S\u00f3 para lembrar, uma as principais raz\u00f5es pelas quais o Microsoft Office \u00e9 adotado consiste justamente na facilidade que possuimos de gerar documentos program\u00e1ticamente. \u00a0<\/p>\n<p>E, convenhamos, a ado\u00e7\u00e3o do ODF trar\u00e1 ganhos para todos, visto que se trata de um formato do qual possuimos 100% de conhecimento a respeito, ao contr\u00e1rio do que ocorre com o Microsoft Office)<\/p>\n<p>Inicialmente, nosso foco consiste na gera\u00e7\u00e3o de planilhas (influenciado pela nossa necessidade atual) e gr\u00e1ficos. Posteriormente, conforme nossas necessidades venham a evoluir, pretendemos abranger outros tipos de documento.<\/p>\n<p>O projeto ainda n\u00e3o possui um site (pretendo construi-lo no decorrer desta semana) para que possamos liberar o c\u00f3digo fonte (cuja licen\u00e7a ser\u00e1 a LGPL), mas j\u00e1 aproveito a ocasi\u00e3o para convid\u00e1-los a participar deste projeto, bastando para isto entrar em contato comigo a partir deste blog.<\/p>\n<p>Sendo assim, nesta semana podem esperar mais posts sobre o desenvolvimento deste projeto neste blog (e, com isto, maiores informa\u00e7\u00f5es sobre como \u00e9 de fato o formato ODF).<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Semana passada, em um de nossos projetos, precisamos gerar alguns gr\u00e1ficos no Excel usando Java. N\u00e3o para nossa surpresa, o suporte a esta funcionalidade do formato Excel \u00e9 extremamente limitada para aqueles que trabalham com Java. Basicamente, vimos duas op\u00e7\u00f5es: Criar um modelo pr\u00e9-definido com um gr\u00e1fico j\u00e1 pr\u00e9-criado e, em seguida, simplesmente preencher algumas [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_coblocks_attr":"","_coblocks_dimensions":"","_coblocks_responsive_height":"","_coblocks_accordion_ie_support":"","site-sidebar-layout":"default","site-content-layout":"","ast-site-content-layout":"","site-content-style":"default","site-sidebar-style":"default","ast-global-header-display":"","ast-banner-title-visibility":"","ast-main-header-display":"","ast-hfb-above-header-display":"","ast-hfb-below-header-display":"","ast-hfb-mobile-header-display":"","site-post-title":"","ast-breadcrumbs-content":"","ast-featured-img":"","footer-sml-layout":"","theme-transparent-header-meta":"","adv-header-id-meta":"","stick-header-meta":"","header-above-stick-meta":"","header-main-stick-meta":"","header-below-stick-meta":"","astra-migrate-meta-layouts":"default","ast-page-background-enabled":"default","ast-page-background-meta":{"desktop":{"background-color":"var(--ast-global-color-4)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-gradient":""},"tablet":{"background-color":"","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-gradient":""},"mobile":{"background-color":"","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-gradient":""}},"ast-content-background-meta":{"desktop":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-gradient":""},"tablet":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-gradient":""},"mobile":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-gradient":""}},"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[6,12],"tags":[],"class_list":["post-84","post","type-post","status-publish","format-standard","hentry","category-java","category-odf"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v22.8 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Gerando arquivos ODF com Java: anunciando o ODFEasy - \/dev\/Kico<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/devkico.itexto.com.br\/?p=84\" \/>\n<meta property=\"og:locale\" content=\"pt_BR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Gerando arquivos ODF com Java: anunciando o ODFEasy - \/dev\/Kico\" \/>\n<meta property=\"og:description\" content=\"Semana passada, em um de nossos projetos, precisamos gerar alguns gr\u00e1ficos no Excel usando Java. N\u00e3o para nossa surpresa, o suporte a esta funcionalidade do formato Excel \u00e9 extremamente limitada para aqueles que trabalham com Java. Basicamente, vimos duas op\u00e7\u00f5es: Criar um modelo pr\u00e9-definido com um gr\u00e1fico j\u00e1 pr\u00e9-criado e, em seguida, simplesmente preencher algumas [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/devkico.itexto.com.br\/?p=84\" \/>\n<meta property=\"og:site_name\" content=\"\/dev\/Kico\" \/>\n<meta property=\"article:published_time\" content=\"2008-09-29T12:01:29+00:00\" \/>\n<meta name=\"author\" content=\"Kico (Henrique Lobo Weissmann)\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@loboweissmann\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"Kico (Henrique Lobo Weissmann)\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. tempo de leitura\" \/>\n\t<meta name=\"twitter:data2\" content=\"3 minutos\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/devkico.itexto.com.br\/?p=84\",\"url\":\"https:\/\/devkico.itexto.com.br\/?p=84\",\"name\":\"Gerando arquivos ODF com Java: anunciando o ODFEasy - \/dev\/Kico\",\"isPartOf\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/#website\"},\"datePublished\":\"2008-09-29T12:01:29+00:00\",\"dateModified\":\"2008-09-29T12:01:29+00:00\",\"author\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/502ab8892631bb005d6da2269fe5a3a7\"},\"breadcrumb\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/?p=84#breadcrumb\"},\"inLanguage\":\"pt-BR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/devkico.itexto.com.br\/?p=84\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/devkico.itexto.com.br\/?p=84#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/devkico.itexto.com.br\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Gerando arquivos ODF com Java: anunciando o ODFEasy\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/devkico.itexto.com.br\/#website\",\"url\":\"https:\/\/devkico.itexto.com.br\/\",\"name\":\"\/dev\/Kico\",\"description\":\"Desenvolvendo software\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/devkico.itexto.com.br\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"pt-BR\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/502ab8892631bb005d6da2269fe5a3a7\",\"name\":\"Kico (Henrique Lobo Weissmann)\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/dd6973d86a689bc63122b2e603f25be3?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/dd6973d86a689bc63122b2e603f25be3?s=96&d=mm&r=g\",\"caption\":\"Kico (Henrique Lobo Weissmann)\"},\"sameAs\":[\"https:\/\/x.com\/loboweissmann\"],\"url\":\"https:\/\/devkico.itexto.com.br\/?author=1\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Gerando arquivos ODF com Java: anunciando o ODFEasy - \/dev\/Kico","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:\/\/devkico.itexto.com.br\/?p=84","og_locale":"pt_BR","og_type":"article","og_title":"Gerando arquivos ODF com Java: anunciando o ODFEasy - \/dev\/Kico","og_description":"Semana passada, em um de nossos projetos, precisamos gerar alguns gr\u00e1ficos no Excel usando Java. N\u00e3o para nossa surpresa, o suporte a esta funcionalidade do formato Excel \u00e9 extremamente limitada para aqueles que trabalham com Java. Basicamente, vimos duas op\u00e7\u00f5es: Criar um modelo pr\u00e9-definido com um gr\u00e1fico j\u00e1 pr\u00e9-criado e, em seguida, simplesmente preencher algumas [&hellip;]","og_url":"https:\/\/devkico.itexto.com.br\/?p=84","og_site_name":"\/dev\/Kico","article_published_time":"2008-09-29T12:01:29+00:00","author":"Kico (Henrique Lobo Weissmann)","twitter_card":"summary_large_image","twitter_creator":"@loboweissmann","twitter_misc":{"Escrito por":"Kico (Henrique Lobo Weissmann)","Est. tempo de leitura":"3 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/devkico.itexto.com.br\/?p=84","url":"https:\/\/devkico.itexto.com.br\/?p=84","name":"Gerando arquivos ODF com Java: anunciando o ODFEasy - \/dev\/Kico","isPartOf":{"@id":"https:\/\/devkico.itexto.com.br\/#website"},"datePublished":"2008-09-29T12:01:29+00:00","dateModified":"2008-09-29T12:01:29+00:00","author":{"@id":"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/502ab8892631bb005d6da2269fe5a3a7"},"breadcrumb":{"@id":"https:\/\/devkico.itexto.com.br\/?p=84#breadcrumb"},"inLanguage":"pt-BR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/devkico.itexto.com.br\/?p=84"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/devkico.itexto.com.br\/?p=84#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/devkico.itexto.com.br\/"},{"@type":"ListItem","position":2,"name":"Gerando arquivos ODF com Java: anunciando o ODFEasy"}]},{"@type":"WebSite","@id":"https:\/\/devkico.itexto.com.br\/#website","url":"https:\/\/devkico.itexto.com.br\/","name":"\/dev\/Kico","description":"Desenvolvendo software","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/devkico.itexto.com.br\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"pt-BR"},{"@type":"Person","@id":"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/502ab8892631bb005d6da2269fe5a3a7","name":"Kico (Henrique Lobo Weissmann)","image":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/dd6973d86a689bc63122b2e603f25be3?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/dd6973d86a689bc63122b2e603f25be3?s=96&d=mm&r=g","caption":"Kico (Henrique Lobo Weissmann)"},"sameAs":["https:\/\/x.com\/loboweissmann"],"url":"https:\/\/devkico.itexto.com.br\/?author=1"}]}},"jetpack_featured_media_url":"","jetpack-related-posts":[],"jetpack_sharing_enabled":true,"jetpack_likes_enabled":true,"_links":{"self":[{"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/posts\/84"}],"collection":[{"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=84"}],"version-history":[{"count":1,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/posts\/84\/revisions"}],"predecessor-version":[{"id":85,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/posts\/84\/revisions\/85"}],"wp:attachment":[{"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=84"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=84"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=84"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}