2015-06-04 22:09:57 +05:30
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2015-06-04 00:06:46 +05:30
|
|
|
/*
|
|
|
|
* This file is part of the LibreOffice project.
|
|
|
|
*
|
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "tilebuffer.hxx"
|
|
|
|
|
2015-06-08 08:02:37 +02:00
|
|
|
#if !GLIB_CHECK_VERSION(2,40,0)
|
|
|
|
#define g_info(...) g_log(G_LOG_DOMAIN, G_LOG_LEVEL_INFO, __VA_ARGS__)
|
|
|
|
#endif
|
|
|
|
|
2015-06-04 22:09:57 +05:30
|
|
|
/* ------------------
|
|
|
|
Utility functions
|
|
|
|
------------------
|
|
|
|
*/
|
2015-06-04 13:56:46 +05:30
|
|
|
float pixelToTwip(float fInput, float zoom)
|
2015-06-04 00:06:46 +05:30
|
|
|
{
|
|
|
|
return (fInput / DPI / zoom) * 1440.0f;
|
|
|
|
}
|
|
|
|
|
2015-06-04 13:56:46 +05:30
|
|
|
float twipToPixel(float fInput, float zoom)
|
2015-06-04 00:06:46 +05:30
|
|
|
{
|
|
|
|
return fInput / 1440.0f * DPI * zoom;
|
|
|
|
}
|
|
|
|
|
2015-07-19 01:03:56 +05:30
|
|
|
static void getTileFunc(GTask*, gpointer, gpointer task_data, GCancellable*)
|
|
|
|
{
|
|
|
|
GdkPixbuf* pPixBuf = gdk_pixbuf_new(GDK_COLORSPACE_RGB, TRUE, 8, nTileSizePixels, nTileSizePixels);
|
|
|
|
GetTileCallbackData* pCallback = static_cast<GetTileCallbackData*>(task_data);
|
|
|
|
TileBuffer* buffer = pCallback->m_pBuffer;
|
|
|
|
int index = pCallback->m_nX * buffer->m_nWidth + pCallback->m_nY;
|
|
|
|
if (!pPixBuf)
|
|
|
|
{
|
|
|
|
g_info ("Error allocating memory to pixbuf");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned char* pBuffer = gdk_pixbuf_get_pixels(pPixBuf);
|
|
|
|
GdkRectangle aTileRectangle;
|
|
|
|
aTileRectangle.x = pixelToTwip(nTileSizePixels, pCallback->m_fZoom) * pCallback->m_nY;
|
|
|
|
aTileRectangle.y = pixelToTwip(nTileSizePixels, pCallback->m_fZoom) * pCallback->m_nX;
|
|
|
|
|
|
|
|
g_test_timer_start();
|
|
|
|
buffer->m_pLOKDocument->pClass->paintTile(buffer->m_pLOKDocument,
|
|
|
|
pBuffer,
|
|
|
|
nTileSizePixels, nTileSizePixels,
|
|
|
|
aTileRectangle.x, aTileRectangle.y,
|
|
|
|
pixelToTwip(nTileSizePixels, pCallback->m_fZoom),
|
|
|
|
pixelToTwip(nTileSizePixels, pCallback->m_fZoom));
|
|
|
|
|
|
|
|
double elapsedTime = g_test_timer_elapsed();
|
|
|
|
g_info ("Rendered (%d, %d) in %f seconds",
|
|
|
|
pCallback->m_nX,
|
|
|
|
pCallback->m_nY,
|
|
|
|
elapsedTime);
|
|
|
|
|
|
|
|
//create a mapping for it
|
|
|
|
buffer->m_mTiles[index].setPixbuf(pPixBuf);
|
|
|
|
buffer->m_mTiles[index].valid = true;
|
|
|
|
}
|
|
|
|
|
2015-06-04 22:09:57 +05:30
|
|
|
/* ----------------------------
|
|
|
|
Tile class member functions
|
|
|
|
----------------------------
|
|
|
|
*/
|
|
|
|
GdkPixbuf* Tile::getBuffer()
|
2015-06-04 00:06:46 +05:30
|
|
|
{
|
2015-06-04 03:32:18 +05:30
|
|
|
return m_pBuffer;
|
2015-06-04 00:06:46 +05:30
|
|
|
}
|
|
|
|
|
2015-06-04 22:09:57 +05:30
|
|
|
void Tile::release()
|
2015-06-04 00:06:46 +05:30
|
|
|
{
|
2015-06-04 03:32:18 +05:30
|
|
|
g_object_unref (m_pBuffer);
|
|
|
|
m_pBuffer = NULL;
|
2015-06-04 00:06:46 +05:30
|
|
|
}
|
|
|
|
|
2015-06-04 22:09:57 +05:30
|
|
|
void Tile::setPixbuf(GdkPixbuf *buffer)
|
|
|
|
{
|
|
|
|
m_pBuffer = buffer;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ----------------------------------
|
|
|
|
TileBuffer class member functions
|
|
|
|
----------------------------------
|
|
|
|
*/
|
|
|
|
void TileBuffer::resetAllTiles()
|
2015-06-04 00:06:46 +05:30
|
|
|
{
|
2015-06-04 03:32:18 +05:30
|
|
|
std::map<int, Tile>::iterator it = m_mTiles.begin();
|
2015-06-14 09:09:52 +02:00
|
|
|
for (; it != m_mTiles.end(); ++it)
|
2015-06-04 22:09:57 +05:30
|
|
|
{
|
2015-07-19 01:03:56 +05:30
|
|
|
it->second.valid = false;
|
2015-06-04 22:09:57 +05:30
|
|
|
}
|
2015-06-04 03:32:18 +05:30
|
|
|
}
|
|
|
|
|
2015-07-19 01:03:56 +05:30
|
|
|
void TileBuffer::setInvalid(int x, int y, float fZoom)
|
2015-06-04 03:32:18 +05:30
|
|
|
{
|
|
|
|
int index = x * m_nWidth + y;
|
2015-06-04 22:09:57 +05:30
|
|
|
g_info("Setting tile invalid (%d, %d)", x, y);
|
2015-06-04 03:32:18 +05:30
|
|
|
if (m_mTiles.find(index) != m_mTiles.end())
|
2015-06-04 22:09:57 +05:30
|
|
|
{
|
2015-06-09 11:48:12 +02:00
|
|
|
m_mTiles[index].valid = false;
|
2015-07-19 01:03:56 +05:30
|
|
|
GTask* task = g_task_new(this, NULL, NULL, NULL);
|
|
|
|
GetTileCallbackData* pCallback = new GetTileCallbackData(x, y, fZoom, this);
|
|
|
|
g_task_set_task_data(task, pCallback, g_free);
|
|
|
|
g_task_run_in_thread(task, getTileFunc);
|
2015-06-04 22:09:57 +05:30
|
|
|
}
|
2015-06-04 00:06:46 +05:30
|
|
|
}
|
|
|
|
|
2015-07-19 01:03:56 +05:30
|
|
|
Tile& TileBuffer::getTile(int x, int y, float aZoom, GTask* task)
|
2015-06-04 00:06:46 +05:30
|
|
|
{
|
2015-06-04 03:32:18 +05:30
|
|
|
int index = x * m_nWidth + y;
|
|
|
|
|
2015-07-19 01:03:56 +05:30
|
|
|
if (m_mTiles.find(index) != m_mTiles.end() && !m_mTiles[index].valid)
|
|
|
|
{
|
|
|
|
GetTileCallbackData* pCallback = new GetTileCallbackData(x, y, aZoom, this);
|
|
|
|
g_task_set_task_data(task, pCallback, g_free);
|
|
|
|
g_task_run_in_thread(task, getTileFunc);
|
|
|
|
return m_mTiles[index];
|
|
|
|
}
|
|
|
|
else if(m_mTiles.find(index) == m_mTiles.end())
|
|
|
|
{
|
|
|
|
GetTileCallbackData* pCallback = new GetTileCallbackData(x, y, aZoom, this);
|
|
|
|
g_task_set_task_data(task, pCallback, g_free);
|
|
|
|
g_info ("running in thread new tile");
|
|
|
|
g_task_run_in_thread(task, getTileFunc);
|
|
|
|
return m_DummyTile;
|
2015-06-04 22:09:57 +05:30
|
|
|
}
|
|
|
|
|
2015-06-04 03:32:18 +05:30
|
|
|
return m_mTiles[index];
|
2015-06-04 00:06:46 +05:30
|
|
|
}
|
|
|
|
|
2015-06-04 22:09:57 +05:30
|
|
|
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|