Является ли обработка изображений в клетках летающей тарелкой ошибкой? - PullRequest
4 голосов
/ 19 апреля 2011

Мне удалось свести мой пример к следующему (он использует несколько достаточно полезных URL-адресов данных, но stackoverflow должен красиво выводить их из игры ...):

static
{
    String oldValue = System.getProperty("java.protocol.handler.pkgs");
    if (oldValue == null)
    {
        System.setProperty("java.protocol.handler.pkgs", "org.xhtmlrenderer.protocols");
    }
    else if (!oldValue.contains("org.xhtmlrenderer.protocols"))
    {
        System.setProperty("java.protocol.handler.pkgs", oldValue + "|org.xhtmlrenderer.protocols");
    }
}

@Test
public void testLegacyCellSpacing() throws Exception
{
    ITextRenderer renderer = new ITextRenderer();

    renderer.setDocumentFromString("<html>\n" +
                                   "  <head>\n" +
                                   "    <title>Some title</title>\n" +
                                   "  </head>\n" +
                                   "  <body>\n" +
                                   "    <div>\n" +
                                   "<table cellpadding=\"0\" cellspacing=\"0\">\n" +
                                   "<tr>\n" +
                                   "<td>\n" +
                                   "   <img src=\"\" width=\"185\" height=\"83\"/>\n" +
                                   "</td>\n" +
                                   "</tr>\n" +
                                   "<tr>\n" +
                                   "<td>\n" +
                                   "   <img src=\"\" width=\"185\" height=\"84\"/>\n" +
                                   "</td>\n" +
                                   "</tr>\n" +
                                   "<tr>\n" +
                                   "<td>\n" +
                                   "   <img src=\"\" width=\"185\" height=\"83\"/>\n" +
                                   "</td>\n" +
                                   "</tr>\n" +
                                   "</table>\n" +
                                   "    </div>\n" +
                                   "  </body>\n" +
                                   "</html>", null);

    renderer.layout();

    File pdfFile = File.createTempFile("TestFlyingSaucer", ".pdf");
    OutputStream output = new BufferedOutputStream(new FileOutputStream(pdfFile));
    try
    {
        renderer.createPDF(output, true);
    }
    finally
    {
        output.close();
    }

    System.out.println(); // breakpointing here to look at the output.  no good assertions available for checking this problem yet. :(
}

Этот код запускается и генерирует файл PDF, в котором между изображениями указаны неправильные пробелы. Я не могу понять, что является причиной пробелов, но я также не могу понять, если это ошибка. Что я знаю:

  1. Веб-браузеры не показывают пробелы между изображениями.
  2. Если вы удалите изображения и замените их чем-то вроде div с фиксированным размером, проблема волшебным образом исчезнет (это доказывает, что летающая тарелка делает правильные вещи с устаревшими атрибутами cellpadding и cellspacing, что было моей первоначальной задачей).
  3. Если вы добавите 1-пиксельную границу к ячейкам (td { border: 1px solid red; }), это показывает, что дополнительное пространство находится за пределами элементов td.
  4. Если вы удалите пробел между <td> и <img, проблема исчезнет.

Мне кажется странным, что дополнительный пробел внутри элемента может привести к дополнительным отступам / полям за пределами элемента. Возможно, я совершенно не понимаю HTML, поэтому надеюсь, что кто-то прямо здесь меня покажет, прежде чем я запихну проблему в их трекер.

(Также: выгрузка типичного коленного ответа «не используйте таблицы для этого» - это не мой HTML, я пытаюсь отобразить HTML в реальном мире после его очистки. В этом примере показано сообщение -Очистить HTML, чтобы исключить проблему в коде очистки.)

1 Ответ

1 голос
/ 03 июня 2011

Браузеры чувствительны к пробелам в HTML во многих местах, в том числе внутри и между элементами, и даже в местах, которые вы не ожидаете. Например, если у вас есть ul с li элементами, если вы используете CSS для стилизации элементов с помощью li {display:inline} для создания горизонтального меню, любой пробел между </li> и следующим <li> будет пробел отдельные пункты меню!

В данном конкретном случае вид отступа первого дочернего элемента в пробел, безусловно, необычен, но я не могу сказать категорически, если это будет считаться ошибкой в ​​соответствии со стандартами HTML. Ваше лучшее решение действительно состоит в том, чтобы просто устранить пустое пространство там, где оно вызывает проблемы.

...