<div dir="ltr"><div><div><div><div><div><div><div>Hi again<br><br></div>I reply here because I have just noticed a very cool new feature in QGIS composer. You can add an HTML box, give a file stored in the disk containing the HTML code to display in the box. I knew this option. What I did not notice was the ability to let QGIS create as many pages as necessary to dispplay the full content of the HTML file related to the box.<br>
<br></div>So instead of passing long parameter to getPrint text boxes to dynamically replace the content (html rendered or not), I could use this feature instead. What is missing for me right now to achieve this goal :<br>
</div>* be able to pass the HTML file path via a parameter. We could use the id of the HTML item in the composer.<br></div>* be able to make it work in getPrint : I managed to create a PDF from QGIS with the HTML content from a file, but could not via QGIS Server: the HTML block stays empty. This is not because of X server, because I can use HTML text for text blocks via the "fake" X server.<br>
<br></div>Any comment appreciated.<br><br></div>Good evening<br></div>Michael<br></div><div class="gmail_extra"><br><br><div class="gmail_quote">2013/5/28 kimaidou <span dir="ltr"><<a href="mailto:kimaidou@gmail.com" target="_blank">kimaidou@gmail.com</a>></span><br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote"><div class="im">2013/5/28 Marco Hugentobler <span dir="ltr"><<a href="mailto:marco.hugentobler@sourcepole.ch" target="_blank">marco.hugentobler@sourcepole.ch</a>></span><br>

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
  
    
  
  <div text="#000000" bgcolor="#FFFFFF">
    <div><div>>So for me, simply removing the
      adjustSizeToText call would be enough. Or we have to make sure
      this method does the job correctly, which may be a bit hard to
      implement : we need to avoid to have >collision with other
      composition items, etc.<br>
      <br></div>
      The problem is if the client provided text does not fit into the
      predefined label box. </div></div></blockquote><div><br></div></div><div>I agree, but it is better than "now", and quite logical to me : if the content does not fit, only the part which fits is visible. This allows the output PDF to be like the author wanted to, with the position and size of each text box as set in the Composer. And above all, text wraps correctly without dynamic resize. We could try to add an option "max length" for the text boxes which could be advertised in the getCapabilities ? This way the client could warn the user whenever he tries to use a text which too many characters ?<br>

</div><div class="im"><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div text="#000000" bgcolor="#FFFFFF"><div>It would be good to combine dynamic resize
      capabilities with line breaks somehow.<br></div></div></blockquote><div><br></div></div><div>I think dynamic resize should be used only if we can use it with line breaks.Better respect the position and size defined by the user in QGIS composer than having a text item which get so long that it get out of the composer limits.<br>

<br></div><div class="im"><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div text="#000000" bgcolor="#FFFFFF"><div>
      I'm open for suggestions.<span><font color="#888888"><br></font></span></div></div></blockquote><div><br></div></div><div>Thanks, and please forgive my english which sometimes prevents me from souding moderate enough. I know that giving ideas is easy and developping features is harder !<br>

<br></div><div>Some suggestions (I am thinking out loud...)<br><br></div><div>* new option with max text length, advertised in the getCapabilities<br></div><div>* linked text boxes. In softwares like Adobe Illustrator, or Scribus (open-source), you can link serveral text boxes, so that the text is written is the first box then in the linked one if the content does not fit the first one. <br>

</div><div>* If "linked" text boxes is implemented, the killer feature would have to dynamically generate new pages with linked text boxes so that all the content is written in as many boxes as necessary to have the full content written down.<br>

<br></div><div>Sincerely<br></div><div>Michael<br></div><div><div class="h5"><div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div text="#000000" bgcolor="#FFFFFF">

<div><span><font color="#888888">
      <br>
      Marco</font></span><div><div><br>
      <br>
      <br>
      On 28.05.2013 11:53, kimaidou wrote:<br>
    </div></div></div><div><div>
    <blockquote type="cite">
      <div dir="ltr">
        <div>
          <div>
            <div>
              <div>
                <div>
                  <div>
                    <div>Hi<br>
                      <br>
                    </div>
                    I just made a small test and commented the line<br>
                    currentLabel->adjustSizeToText();<br>
                  </div>
                  Then recompile QGIS master and tested it with a
                  classical text box (not html rendered) with a long
                  text.<br>
                  <br>
                </div>
                I personnaly prefer the behaviour when this method is
                not called : the text box keep the size set by the user
                in QGIS. And the text wraps when it reaches the right
                side of the Box. I even tried with "HTML rendered" on
                (and my fake X Server running), and it worked well too.<br>
                <br>
              </div>
              At the contrary, when adjustSizeToText is used, the box is
              transformed in a one line box, which goes to the right of
              the entire composition (out of it) : text does not wrap. <br>
              <br>
            </div>
            So for me, simply removing the adjustSizeToText call would
            be enough. Or we have to make sure this method does the job
            correctly, which may be a bit hard to implement : we need to
            avoid to have collision with other composition items, etc.<br>
            <br>
          </div>
          Regards<br>
        </div>
        Michael<br>
        <div>
          <div>
            <div>
              <div>
                <div><br>
                </div>
              </div>
            </div>
          </div>
        </div>
      </div>
      <div class="gmail_extra"><br>
        <br>
        <div class="gmail_quote">2013/5/28 René-Luc D'Hont <span dir="ltr"><<a href="mailto:rldhont@gmail.com" target="_blank">rldhont@gmail.com</a>></span><br>
          <blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
            <div dir="ltr">Hi Marco<br>
              <div>
                <div class="gmail_extra"><br>
                  <div class="gmail_quote">
                    <div>
                      <blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
                        <div>
                          <br>
                        </div>
                        I guess yes. 'adjustSizeToText()' works for
                        text, not html. Html support for composer label
                        was added recently to the composer label class.
                        Please adapt the relevant lines to work with
                        html labels too. </blockquote>
                      <div><br>
                      </div>
                    </div>
                    <div>I'll adapt it<br>
                    </div>
                    <div>
                      <div> </div>
                      <blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
                        <div>
                          <br>
                          >Question for Marco, Why removed label, if
                          the request doesn't define a value ? Why not
                          used the default value ?<br>
                          <br>
                        </div>
                        The idea was that the web client has the
                        possibility to remove an advertised text label
                        completely if it is not used. E.g. if a
                        composition defines a text item with id
                        'author', the web client can simply ignore it if
                        it does not want to have author's name printed.
                        Note that the labels without ids are not removed
                        as they are considered to be fix, so not subject
                        to client text replacement (original meaning of
                        label id was that this text item is subject to
                        text replacement by web client. Later, the id
                        has been generalized as an id for every item
                        type).<br>
                        <br>
                        Another possibility would be to remove the item
                        only if the client gives an empty text and use
                        the default text otherwise. What do you think?<br>
                      </blockquote>
                      <div><br>
                        <br>
                      </div>
                    </div>
                    <div>I prefer to remove the label only if the user
                      gives an empty text.<br>
                    </div>
                    <div>Can I do it ?<br>
                      <br>
                      <br>
                    </div>
                    <div>Regards,<br>
                    </div>
                    <div>René-Luc<br>
                    </div>
                    <div>
                      <div>
                        <div> <br>
                          <br>
                          On <a href="tel:27.05.2013%2022" value="+12705201322" target="_blank">27.05.2013
                            22</a>:23, rldhont wrote:<br>
                        </div>
                        <blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
                          <blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
                            <div>
                              <div>
                                Hi Marco and other devs,<br>
                                <br>
                                In src/mapserver/qgsconfigparser.cpp:530
                                we can read :<br>
                                <br>
                                  //replace label text<br>
                                  foreach ( QgsComposerLabel
                                *currentLabel, composerLabels )<br>
                                  {<br>
                                    QString title = parameterMap.value(
                                currentLabel->id().toUpper() );<br>
                                <br>
                                    if ( title.isEmpty() )<br>
                                    {<br>
                                      //remove exported labels not
                                referenced in the request<br>
                                      if (
                                !currentLabel->id().isEmpty() )<br>
                                      {<br>
                                        c->removeItem( currentLabel
                                );<br>
                                        delete currentLabel;<br>
                                      }<br>
                                      continue;<br>
                                    }<br>
                                <br>
                                    currentLabel->setText( title );<br>
                                    currentLabel->adjustSizeToText();<br>
                                  }<br>
                                <br>
                                This code is used to draw composer label
                                with value defined by the QGIS WMS
                                Server Request GetPrint.<br>
                                <br>
                                The bug defined in the issues #7894 <a href="http://hub.qgis.org/issues/7894" target="_blank">http://hub.qgis.org/issues/7894</a>
                                is probably du to the method
                                adjustSizeToText()<br>
                                Someone can confim it ?<br>
                                <br>
                                Question for Marco, Why removed label,
                                if the request doesn't define a value ?
                                Why not used the default value ?<br>
                                <br>
                                Regards,<br>
                                René-Luc D'Hont<br>
                                3Liz<br>
                              </div>
                            </div>
                            _______________________________________________<br>
                            Qgis-developer mailing list<br>
                            <a href="mailto:Qgis-developer@lists.osgeo.org" target="_blank">Qgis-developer@lists.osgeo.org</a><br>
                            <a href="http://lists.osgeo.org/mailman/listinfo/qgis-developer" target="_blank">http://lists.osgeo.org/mailman/listinfo/qgis-developer</a><span><font color="#888888"><br>
                              </font></span></blockquote>
                          <span><font color="#888888">
                              <br>
                              <br>
                              -- <br>
                              Dr. Marco Hugentobler<br>
                              Sourcepole -  Linux & Open Source
                              Solutions<br>
                              Weberstrasse 5, CH-8004 Zürich,
                              Switzerland<br>
                              <a href="mailto:marco.hugentobler@sourcepole.ch" target="_blank">marco.hugentobler@sourcepole.ch</a>
                              <a href="http://www.sourcepole.ch" target="_blank">http://www.sourcepole.ch</a><br>
                              Technical Advisor QGIS Project Steering
                              Committee<br>
                              <br>
                              _______________________________________________<br>
                              Qgis-developer mailing list<br>
                              <a href="mailto:Qgis-developer@lists.osgeo.org" target="_blank">Qgis-developer@lists.osgeo.org</a><br>
                              <a href="http://lists.osgeo.org/mailman/listinfo/qgis-developer" target="_blank">http://lists.osgeo.org/mailman/listinfo/qgis-developer</a><br>
                            </font></span></blockquote>
                      </div>
                    </div>
                  </div>
                  <br>
                </div>
              </div>
            </div>
            <br>
            _______________________________________________<br>
            Qgis-developer mailing list<br>
            <a href="mailto:Qgis-developer@lists.osgeo.org" target="_blank">Qgis-developer@lists.osgeo.org</a><br>
            <a href="http://lists.osgeo.org/mailman/listinfo/qgis-developer" target="_blank">http://lists.osgeo.org/mailman/listinfo/qgis-developer</a><br>
            <br>
          </blockquote>
        </div>
        <br>
      </div>
    </blockquote>
    <br>
    <br>
    <pre cols="72">-- 
Dr. Marco Hugentobler
Sourcepole -  Linux & Open Source Solutions
Weberstrasse 5, CH-8004 Zürich, Switzerland
<a href="mailto:marco.hugentobler@sourcepole.ch" target="_blank">marco.hugentobler@sourcepole.ch</a> <a href="http://www.sourcepole.ch" target="_blank">http://www.sourcepole.ch</a>
Technical Advisor QGIS Project Steering Committee </pre>
  </div></div></div>

<br>_______________________________________________<br>
Qgis-developer mailing list<br>
<a href="mailto:Qgis-developer@lists.osgeo.org" target="_blank">Qgis-developer@lists.osgeo.org</a><br>
<a href="http://lists.osgeo.org/mailman/listinfo/qgis-developer" target="_blank">http://lists.osgeo.org/mailman/listinfo/qgis-developer</a><br>
<br></blockquote></div></div></div><br></div></div>
</blockquote></div><br></div>