Geom/Ctrl/PlotterCtrl: new methods to check for reversed orientation of coordinate axes

plugin/jpg/jpgupp.cpp: support for EXIM image orientation metadata
plugin/sqlite3/Sqlite3upp.cpp: support for BLOB write using SqlRaw
Oracle/Oci8.cpp: fixed OracleBlob::Write to survive zero-length write

git-svn-id: svn://ultimatepp.org/upp/trunk@4100 f0d560ea-af0d-0410-9eb7-867de7ffcac7
This commit is contained in:
rylek 2011-10-24 21:30:07 +00:00
parent dd90c9d1f7
commit a4947790ef
5 changed files with 52 additions and 5 deletions

View file

@ -1203,12 +1203,31 @@ Image ZoomOutDragDrop::Cursor(Pointf pt, dword keyflags, bool dragging) const
} }
bool ZoomOutDragDrop::Push(Pointf pt, dword keyflags) bool ZoomOutDragDrop::Push(Pointf pt, dword keyflags)
{
return true;
}
void ZoomOutDragDrop::DropRect(const Rectf& rc, dword keyflags)
{
Rectf view_rc = owner.GetViewRect();
Rect screen_rc = owner.ToClient(rc);
Sizef new_scale = (Sizef)max(screen_rc.Size(), Size(10, 10)) / view_rc.Size();
double aspect = owner.GetAspectRatio();
if(aspect != 0)
new_scale = max(new_scale, Sizef(new_scale.cy / aspect, new_scale.cx * aspect));
if(owner.IsReversedX()) new_scale.cx = -new_scale.cx;
if(owner.IsReversedY()) new_scale.cy = -new_scale.cy;
Pointf new_delta = Pointf(screen_rc.CenterPoint()) - new_scale * Sizef(view_rc.CenterPoint());
owner.SetZoom(new_scale, new_delta);
owner.WhenUserZoom();
}
void ZoomOutDragDrop::Click(Pointf pt, dword keyflags)
{ {
Rectf rc = GetOwner().GetViewRect(); Rectf rc = GetOwner().GetViewRect();
rc.Inflate(rc.Size() * 0.5); rc.Inflate(rc.Size() * 0.5);
owner.Zoom(rc + pt - rc.CenterPoint()); owner.Zoom(rc + pt - rc.CenterPoint());
owner.WhenUserZoom(); owner.WhenUserZoom();
return false;
} }
////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////

View file

@ -125,6 +125,10 @@ public:
double GetAvgScale() const; double GetAvgScale() const;
Pointf GetDelta() const { return delta; } Pointf GetDelta() const { return delta; }
Pointf GetPushDelta() const { return push_delta; } Pointf GetPushDelta() const { return push_delta; }
bool IsReversedX() const { return rev_x; }
bool IsReversedY() const { return rev_y; }
bool IsReversing() const { return scale.cx * scale.cy < 0; } bool IsReversing() const { return scale.cx * scale.cy < 0; }
Sizef GetPhysicalZoom() const; Sizef GetPhysicalZoom() const;
@ -320,6 +324,8 @@ public:
virtual Image Cursor(Pointf pt, dword keyflags, bool dragging) const; virtual Image Cursor(Pointf pt, dword keyflags, bool dragging) const;
virtual bool Push(Pointf pt, dword keyflags); virtual bool Push(Pointf pt, dword keyflags);
virtual void DropRect(const Rectf& rc, dword keyflags);
virtual void Click(Pointf pt, dword keyflags);
private: private:
PlotterCtrl& owner; PlotterCtrl& owner;

View file

@ -1491,9 +1491,11 @@ void OracleBlob::Write(int64 at, const void *ptr, dword size) {
ASSERT(IsOpen() && (style & STRM_WRITE) && session); ASSERT(IsOpen() && (style & STRM_WRITE) && session);
ASSERT(at == (dword)at); ASSERT(at == (dword)at);
ub4 n = size; ub4 n = size;
if(session->oci8.OCILobWrite(session->svchp, session->errhp, locp, &n, (dword)at + 1, (void *)ptr, size, int res = session->oci8.OCILobWrite(session->svchp, session->errhp, locp, &n, (dword)at + 1, (void *)ptr, size,
OCI_ONE_PIECE, NULL, NULL, 0, SQLCS_IMPLICIT) != OCI_SUCCESS || n != size) OCI_ONE_PIECE, NULL, NULL, 0, SQLCS_IMPLICIT);
if(res != OCI_SUCCESS || n != size)
{ {
RLOG("OracleBlob::Write(" << at << ", " << size << "): res = " << res << ", n = " << n);
SetError(); SetError();
} }
} }

View file

@ -26,6 +26,17 @@ enum
ROW_BUF_SIZE = 16384, ROW_BUF_SIZE = 16384,
}; };
enum {
EXIF_BYTE = 1, // An 8-bit unsigned integer
EXIF_ASCII = 2, // An 8-bit byte containing one 7-bit ASCII code. The final byte is terminated with NULL
EXIF_SHORT = 3, // A 16-bit (2-byte) unsigned integer
EXIF_LONG = 4, // A 32-bit (4-byte) unsigned integer
EXIF_RATIONAL = 5, // Two LONGs. The first LONG is the numerator and the second LONG expresses the denominator
EXIF_UNDEFINED = 7, // An 8-bit byte that can take any value depending on the field definition
EXIF_SLONG = 9, // A 32-bit (4-byte) signed integer (2's complement notation)
EXIF_SRATIONAL = 10, // Two SLONGs. The first SLONG is the numerator and the second SLONG is the denominator
};
struct jpg_stream_destination_mgr struct jpg_stream_destination_mgr
{ {
jpeg_destination_mgr pub; jpeg_destination_mgr pub;
@ -336,13 +347,17 @@ int JPGRaster::Data::ExifDir(const char *begin, int offset, IFD_TYPE type)
} }
} }
else if(type == GPS_IFD) { else if(type == GPS_IFD) {
if((tag == 2 || tag == 4) && fmt == 5 && count == 3) { if((tag == 2 || tag == 4) && fmt == EXIF_RATIONAL && count == 3) {
metadata.Add(tag == 2 ? "GPSLatitude" : "GPSLongitude", metadata.Add(tag == 2 ? "GPSLatitude" : "GPSLongitude",
ExifF5(data + 0) + ExifF5(data + 8) / 60 + ExifF5(data + 16) / 3600); ExifF5(data + 0) + ExifF5(data + 8) / 60 + ExifF5(data + 16) / 3600);
// puts(NFormat("GPSLatitude: %n %n %n", n1, n2, n3)); // puts(NFormat("GPSLatitude: %n %n %n", n1, n2, n3));
} }
else if(tag == 6 && fmt == 5 && count == 1) else if(tag == 6 && fmt == EXIF_RATIONAL && count == 1)
metadata.Add("GPSAltitude", ExifF5(data)); metadata.Add("GPSAltitude", ExifF5(data));
else if(tag == 16 && fmt == EXIF_ASCII && count == 2 && *data)
metadata.Add("GPSImgDirectionRef", String(*data, 1));
else if(tag == 17 && fmt == EXIF_RATIONAL && count == 1)
metadata.Add("GPSImgDirection", ExifF5(data + 0));
} }
} }
int nextoff = Exif32(e); int nextoff = Exif32(e);

View file

@ -84,6 +84,11 @@ void Sqlite3Connection::BindParam(int i, const Value& r) {
if (IsNull(r)) if (IsNull(r))
sqlite3_bind_null(current_stmt,i); sqlite3_bind_null(current_stmt,i);
else switch (r.GetType()) { else switch (r.GetType()) {
case SQLRAW_V: {
SqlRaw p = r;
sqlite3_bind_blob(current_stmt, i, p, p.GetLength(), SQLITE_TRANSIENT);
break;
}
case STRING_V: case STRING_V:
case WSTRING_V: { case WSTRING_V: {
WString p = r; WString p = r;