ntg-context - mailing list for ConTeXt users
 help / color / mirror / Atom feed
From: Vit Zyka <vit.zyka@seznam.cz>
Subject: Re: Re: externalfigure
Date: Tue, 14 Sep 2004 13:02:02 +0200	[thread overview]
Message-ID: <4146CFAA.2010005@seznam.cz> (raw)
In-Reply-To: <m2hdq16bfs.fsf@levana.de>

>>So I thing the case should work as expected. Could you send
>>complete-and-minimal example?
> 
> 
> \starttext
> \startMPcode
> externalfigure "hacker.jpg" scaled 300;
> \stopMPcode
> \stoptext

It seems to me the behaviour is perhaps not intuitive but correct. I try 
to explain:

Imagine externalfigure without scaling:
   externalfigure "hacker.jpg";
What we will obtain? One can imagine the image in its natural size. That 
  is not the case. We obtain the image of the size 1pt x 1pt. I thing 
there are two reasons for that:
1) Analogy. Imagine this example:
      draw origin--(1,0)--(1,1)--(0,1)--cycle;
    it is exactly the same as
      draw origin--(1pt,0)--(1pt,1pt)--(0,1pt)--cycle;
    and it is abbreviated to
      draw unitsquare;
    and im most cases it is used with scaling
      draw unitsquare xscaled 2cm yscaled 1cm;
    since
      scaled X = xscaled X yscaled X
    then
      unitsquare scaled 2cm
    is still square.

    If you do not specify the unit, the pt is deduced.
    So there is an analogy:
      "unitfigure" 1pt x 1pt = externalfigure "file"

2) Technician. The scaling dimensions are calculated by TeX engine.
    It is done by tricks in pt units, so image 1pt x 1pt simplifies
    the calculations.

If you want to use a bitmap in ConTeXt MP environment in its natural 
size, I suggest to precalculate (according to Hans macro \MPfigure) its 
dimmensions:

% ------------------------------------
\def\getMPfiguresize#1{%
    \getfiguredimensionsonly[#1]%
    \freezedimenmacro\naturalfigurewidth
    \freezedimenmacro\naturalfigureheight
}
\def\naturalMPfigure#1{%
   externalfigure "#1"
     xscaled \naturalfigurewidth\space
     yscaled \naturalfigureheight\space
}
\starttext
\getMPfiguresize{hacker.jpg}
\startMPcode
   \naturalMPfigure{hacker.jpg} ; % space in front of ; is important!!
\stopMPcode
\startMPcode
   \naturalMPfigure{hacker.jpg} scaled 2 slanted .3;
\stopMPcode
\stoptext
%-------------------------

Vit Zyka

-- 
Vít Zýka --- http://typokvitek.com
     Automatic document typesetting
     Automaticka sazba dokumentu --
--

  parent reply	other threads:[~2004-09-14 11:02 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2004-09-13 12:07 externalfigure Jan-Mark Batke
2004-09-13 19:49 ` externalfigure Patrick Gundlach
2004-09-13 20:24   ` externalfigure Vit Zyka
2004-09-13 22:39     ` externalfigure Patrick Gundlach
2004-09-14  8:36       ` externalfigure Hans Hagen
2004-09-15 18:39         ` space in \inmargin Martin Kolarík
2004-09-16  7:41           ` Hans Hagen
2004-09-14 11:02       ` Vit Zyka [this message]
2004-09-15 21:31         ` Re: externalfigure Jan-Mark Batke

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4146CFAA.2010005@seznam.cz \
    --to=vit.zyka@seznam.cz \
    --cc=ntg-context@ntg.nl \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).