77 lines
2.5 KiB
C
77 lines
2.5 KiB
C
|
/**
|
||
|
* PANDA 3D SOFTWARE
|
||
|
* Copyright (c) Carnegie Mellon University. All rights reserved.
|
||
|
*
|
||
|
* All use of this software is subject to the terms of the revised BSD
|
||
|
* license. You should have received a copy of this license along
|
||
|
* with this source code in a file named "LICENSE."
|
||
|
*
|
||
|
* @file cylindricalLens.h
|
||
|
* @author drose
|
||
|
* @date 2001-12-12
|
||
|
*/
|
||
|
|
||
|
#ifndef CYLINDRICALLENS_H
|
||
|
#define CYLINDRICALLENS_H
|
||
|
|
||
|
#include "pandabase.h"
|
||
|
|
||
|
#include "lens.h"
|
||
|
|
||
|
/**
|
||
|
* A cylindrical lens. This is the kind of lens generally used for extremely
|
||
|
* wide panoramic shots. It behaves like a normal perspective lens in the
|
||
|
* vertical direction, but it is non-linear in the horizontal dimension: a
|
||
|
* point on the film corresponds to a point in space in linear proportion to
|
||
|
* its angle to the camera, not to its straight-line distance from the center.
|
||
|
*
|
||
|
* This allows up to 360 degree lenses in the horizontal dimension, with
|
||
|
* relatively little distortion. The distortion is not very apparent between
|
||
|
* two relatively nearby points on the film, but it becomes increasingly
|
||
|
* evident as you compare points widely spaced on the film.
|
||
|
*/
|
||
|
class EXPCL_PANDAFX CylindricalLens : public Lens {
|
||
|
PUBLISHED:
|
||
|
INLINE CylindricalLens();
|
||
|
|
||
|
public:
|
||
|
INLINE CylindricalLens(const CylindricalLens ©);
|
||
|
INLINE void operator = (const CylindricalLens ©);
|
||
|
|
||
|
public:
|
||
|
virtual PT(Lens) make_copy() const;
|
||
|
|
||
|
protected:
|
||
|
virtual bool do_extrude(const Lens::CData *lens_cdata, const LPoint3 &point2d,
|
||
|
LPoint3 &near_point, LPoint3 &far_point) const;
|
||
|
virtual bool do_extrude_vec(const Lens::CData *lens_cdata, const LPoint3 &point2d,
|
||
|
LVector3 &vec) const;
|
||
|
virtual bool do_project(const Lens::CData *lens_cdata,
|
||
|
const LPoint3 &point3d, LPoint3 &point2d) const;
|
||
|
|
||
|
virtual PN_stdfloat fov_to_film(PN_stdfloat fov, PN_stdfloat focal_length, bool horiz) const;
|
||
|
virtual PN_stdfloat fov_to_focal_length(PN_stdfloat fov, PN_stdfloat film_size, bool horiz) const;
|
||
|
virtual PN_stdfloat film_to_fov(PN_stdfloat film_size, PN_stdfloat focal_length, bool horiz) const;
|
||
|
|
||
|
public:
|
||
|
virtual TypeHandle get_type() const {
|
||
|
return get_class_type();
|
||
|
}
|
||
|
virtual TypeHandle force_init_type() {init_type(); return get_class_type();}
|
||
|
static TypeHandle get_class_type() {
|
||
|
return _type_handle;
|
||
|
}
|
||
|
static void init_type() {
|
||
|
Lens::init_type();
|
||
|
register_type(_type_handle, "CylindricalLens",
|
||
|
Lens::get_class_type());
|
||
|
}
|
||
|
|
||
|
private:
|
||
|
static TypeHandle _type_handle;
|
||
|
};
|
||
|
|
||
|
#include "cylindricalLens.I"
|
||
|
|
||
|
#endif
|