Re: [fpc-pascal] Calculating Pixels to represent 3D coordinates

2019-09-17 Thread Thomas Young via fpc-pascal
This is an isometric projection I use:
var H1 = (Y - X) * 0.86602 + ScreenOrgin_H;
var V1 = (X + Y) * 0.5 - Z + ScreenOrgin_V;

Thomas Young
330-256-7064
Sent from my iPhone

> On Sep 17, 2019, at 4:53 PM, Gustavo Enrique Jimenez  
> wrote:
> 
> A simple transformation is:
> 
> P3D=(X,Y,Z)
> P2D=(x,y)
> 
> x=X+Y*0.707
> y=Y*0.707+Z
> 
> I did not tried it, but I think that this is the transformation that
> you are looking for.
> 
> 
> Gustavo
> 
> El mar., 17 sept. 2019 a las 17:37, James Richters
> () escribió:
>> 
>>> What exactly are you trying to do? Usually if you’re doing 3D this all 
>>> happens on the GPU and you get back a color/depth buffer. Maybe you need to 
>>> know where a 2D coordinate is in 3D space?
>> 
>> What I'm trying to do is much simpler than rendering a 3D object..  All I'm 
>> trying to do is display a 3D line drawing or wireframe on the screen.  I 
>> don't need it to dynamically rotate or anything, and it doesn't need to show 
>> any surfaces, textures, lighting, reflections, or shadows, just give a 
>> representation of the XYZ points and lines connecting 2 pair of XYZ 
>> coordinates on the screen.   The purpose of this is to show a 3D 
>> representation of a CNC tool path including the Z movements.
>> 
>> James
>> ___
>> fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
>> https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal
> ___
> fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
> https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal

___
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal


Re: [fpc-pascal] Talkback and detecting touch events

2019-09-17 Thread Thomas Young via fpc-pascal
Hi, 
Years ago I had a career as a technical illustrator. First analog then digital. 
Perhaps the following code I developed back around 1992 might be helpful to you.

H = Horizontal coordinate on picture plane.

V = Vertical coordinate on picture plane.

XYZ = 3D coordinate.

distance = "camera" distance from the model:
a range of values [0..15000] (logrithmic).

height = "camera" height from 0 ground plane.

H := scale * (X * distance / (Y + distance)) + H_offset;
V := scale * ((Z - height) * D / (Y + distance)) + Y_offset;

Thomas Young
330-256-7064
Sent from my iPhone

> On Sep 17, 2019, at 11:20 AM, Mgr. Janusz Chmiel  
> wrote:
> 
> Please would somebody of us try to tell Me, if Android API functions can 
> detect how many fingers have been used to touch The display even while 
> Talkback screen reader work ane Explore by touch service is communicating 
> with display?
> I do not want to use graphical mode, since it require that Talkback screen 
> reader must be turned off. One developer, who have used Java language used 
> some technique, which could detect how many fingers have been used to shift 
> from down to up. If one or two. Thank you very much for yours tips how to 
> detect this specific touch events when Talkback is running.
> ___
> fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
> https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal
___
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal


Re: [fpc-pascal] Calculating Pixels to represent 3D coordinates

2019-09-17 Thread Karoly Balogh (Charlie/SGR)
Hi,

On Tue, 17 Sep 2019, James Richters wrote:

> What I'm trying to do is much simpler than rendering a 3D object..  All
> I'm trying to do is display a 3D line drawing or wireframe on the
> screen.  I don't need it to dynamically rotate or anything, and it
> doesn't need to show any surfaces, textures, lighting, reflections, or
> shadows, just give a representation of the XYZ points and lines
> connecting 2 pair of XYZ coordinates on the screen.  The purpose of this
> is to show a 3D representation of a CNC tool path including the Z
> movements.

Well, it all boils down to the projection you want to make while you
transform from your coordinates from 3D to 2D. For the most simple
"isometric" projection with no perspective, you just throw away one of the
XYZ coordinates, and use the other two - this will result in a simple
"camera" which views at your object from either the front (XY), side (YZ)
or from the top (XZ). (Actually, this also depends on wether in your
coordinate system Y or Z represents depth, 3D editors/engines don't even
agree on this one, the code below assumes "Z" is depth.)

For a simple "perspective" projection, you can use a simplistic formula,
something like:

{ untested pseudocode }
procedure perspective_vertex(const v: T3DVertex; ZCenter: single;
  out X, Y: single);
var
  rdist1: single;
begin
  zdist1:=1.0 / (v.z - zcenter);
  X:=(v.x * zcenter) * zdist1;
  Y:=(v.y * zcenter) * zdist1;
end;

This will put some sort of "perspective" on your 3D vertex, depending on
its Z coordinate. The ZCenter should be larger than the maximum dimension
of your object facing the "camera". Note that this formula is massively
simplified, but serves as the most simple perspective projection.

After this, you can use x/y coordinates to feed the wireframe drawer using
whatever drawing unit you see fit. You might need to do inc(x,width/2);
and inc(y,height/2); and/or multiply your values with a certain
scale-factor, depending on the size of your object, and how its
coordinates map to your 2D resolution.

All of the above methods assume that your object's 3D center resides at
the origo (center of the coordinate system). Anything more complicated
would require some proper matrices to be set up and calculate a full
series of model, view, and projection matrices, as others have already
mentioned, or would require pre-processing your 3D coordinates in a
certain way, so this simplistic formula can work.

Hope this helps,
--
Charlie

(Ps: actually, the FPC Packages contain two similar examples of a rotating
3D cube, for PalmOS and Atari, both written by me, to showcase the m68k
code generator and the units for these retro/niche OSes. They're at (SVN
trunk):

- packages/tosunits/examples/gemcube.pas
- packages/palmunits/examples/palmcube.pas

Showcased here (with video):
https://twitter.com/chainq/status/945010617672523777
https://twitter.com/chainq/status/948865605209387010

These show this most simplistic form of 3D calculation, and they also use
fixed point math, as that fit the only a few mhz fast 68000 CPUs in these
machines. But the basic algo and formula is the same with float and on
faster platforms. Now I'm quite tempted to make a ptc-graph version. :) )
___
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal


Re: [fpc-pascal] Calculating Pixels to represent 3D coordinates

2019-09-17 Thread Wolf
What you are trying to do is write a very simple CAD program. Have a 
look at this link 
, 
which gives the basic formulae and also Pascal routines to do it.


Wolf

On 18/09/19 2:10 AM, James Richters wrote:

I'm curious if Freepascal has any package available that would calculate X,Y 
screen pixels based on 3D  X,Y,Z  data at some given rotations.  I'm using 
Agg-Pas with PTC-Graph in a console application on Windows.   I'm not sure what 
the technical term is for figuring out what pixels are used to represent 3D 
coordinates on a 2D screen, but I'm hoping maybe there is something that just 
does the calculations that I can use in conjunction with Agg-Pas and PTC-Graph 
instead of moving to a complete graphics package.

James
___
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal
___
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal


Re: [fpc-pascal] Calculating Pixels to represent 3D coordinates

2019-09-17 Thread Gustavo Enrique Jimenez
A simple transformation is:

P3D=(X,Y,Z)
P2D=(x,y)

x=X+Y*0.707
y=Y*0.707+Z

I did not tried it, but I think that this is the transformation that
you are looking for.


Gustavo

El mar., 17 sept. 2019 a las 17:37, James Richters
() escribió:
>
> >What exactly are you trying to do? Usually if you’re doing 3D this all 
> >happens on the GPU and you get back a color/depth buffer. Maybe you need to 
> >know where a 2D coordinate is in 3D space?
>
> What I'm trying to do is much simpler than rendering a 3D object..  All I'm 
> trying to do is display a 3D line drawing or wireframe on the screen.  I 
> don't need it to dynamically rotate or anything, and it doesn't need to show 
> any surfaces, textures, lighting, reflections, or shadows, just give a 
> representation of the XYZ points and lines connecting 2 pair of XYZ 
> coordinates on the screen.   The purpose of this is to show a 3D 
> representation of a CNC tool path including the Z movements.
>
> James
> ___
> fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
> https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal
___
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal


Re: [fpc-pascal] Calculating Pixels to represent 3D coordinates

2019-09-17 Thread James Richters
>What exactly are you trying to do? Usually if you’re doing 3D this all happens 
>on the GPU and you get back a color/depth buffer. Maybe you need to know where 
>a 2D coordinate is in 3D space?

What I'm trying to do is much simpler than rendering a 3D object..  All I'm 
trying to do is display a 3D line drawing or wireframe on the screen.  I don't 
need it to dynamically rotate or anything, and it doesn't need to show any 
surfaces, textures, lighting, reflections, or shadows, just give a 
representation of the XYZ points and lines connecting 2 pair of XYZ coordinates 
on the screen.   The purpose of this is to show a 3D representation of a CNC 
tool path including the Z movements.   

James
___
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal


Re: [fpc-pascal] Calculating Pixels to represent 3D coordinates

2019-09-17 Thread Ryan Joseph
What exactly are you trying to do? Usually if you’re doing 3D this all happens 
on the GPU and you get back a color/depth buffer. Maybe you need to know where 
a 2D coordinate is in 3D space?

> On Sep 17, 2019, at 10:10 AM, James Richters  
> wrote:
> 
> I'm curious if Freepascal has any package available that would calculate X,Y 
> screen pixels based on 3D X,Y,Z  data at some given rotations.  I'm using 
> Agg-Pas with PTC-Graph in a console application on Windows.   I'm not sure 
> what the technical term is for figuring out what pixels are used to represent 
> 3D coordinates on a 2D screen, but I'm hoping maybe there is something that 
> just does the calculations that I can use in conjunction with Agg-Pas and 
> PTC-Graph instead of moving to a complete graphics package.

Regards,
Ryan Joseph

___
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal


Re: [fpc-pascal] Calculating Pixels to represent 3D coordinates

2019-09-17 Thread Graeme Geldenhuys
On 17/09/2019 3:10 pm, James Richters wrote:
> I'm not sure what the technical term is for figuring out what pixels
> are used to represent 3D coordinates on a 2D screen, but I'm hoping
> maybe there is something that just does the calculations that I can
> use

https://en.wikipedia.org/wiki/Ray_tracing_(graphics)

Regards,
  Graeme

-- 
fpGUI Toolkit - a cross-platform GUI toolkit using Free Pascal
http://fpgui.sourceforge.net/

My public PGP key:  http://tinyurl.com/graeme-pgp
___
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal


[fpc-pascal] Talkback and detecting touch events

2019-09-17 Thread Mgr. Janusz Chmiel
Please would somebody of us try to tell Me, if Android API functions can detect 
how many fingers have been used to touch The display even while Talkback screen 
reader work ane Explore by touch service is communicating with display?
I do not want to use graphical mode, since it require that Talkback screen 
reader must be turned off. One developer, who have used Java language used some 
technique, which could detect how many fingers have been used to shift from 
down to up. If one or two. Thank you very much for yours tips how to detect 
this specific touch events when Talkback is running.___
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal


Re: [fpc-pascal] Calculating Pixels to represent 3D coordinates

2019-09-17 Thread Sven Barth via fpc-pascal
James Richters  schrieb am Di., 17. Sep.
2019, 16:15:

> I'm curious if Freepascal has any package available that would calculate
> X,Y screen pixels based on 3D  X,Y,Z  data at some given rotations.  I'm
> using Agg-Pas with PTC-Graph in a console application on Windows.   I'm not
> sure what the technical term is for figuring out what pixels are used to
> represent 3D coordinates on a 2D screen, but I'm hoping maybe there is
> something that just does the calculations that I can use in conjunction
> with Agg-Pas and PTC-Graph instead of moving to a complete graphics package.
>

You're essentially looking for a software renderer/rasterizer. Lookup
things like projection matrix and model view matrix.

You can also take a look at the "Ray Tracing in one weekend" books (
https://github.com/RayTracing/raytracing.github.io ) to get a feeling for
what's required.

In the end you might be better served to use a graphics package or at least
OpenGL.

Regards,
Sven

>
___
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal


[fpc-pascal] Calculating Pixels to represent 3D coordinates

2019-09-17 Thread James Richters
I'm curious if Freepascal has any package available that would calculate X,Y 
screen pixels based on 3D  X,Y,Z  data at some given rotations.  I'm using 
Agg-Pas with PTC-Graph in a console application on Windows.   I'm not sure what 
the technical term is for figuring out what pixels are used to represent 3D 
coordinates on a 2D screen, but I'm hoping maybe there is something that just 
does the calculations that I can use in conjunction with Agg-Pas and PTC-Graph 
instead of moving to a complete graphics package.

James
___
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal