2023-08-16 00:20:26 +10:00
|
|
|
/* SPDX-FileCopyrightText: 2012-2023 Blender Authors
|
2023-06-14 23:30:43 +10:00
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: GPL-2.0-or-later */
|
2014-01-28 23:24:59 +09:00
|
|
|
|
2019-02-18 08:08:12 +11:00
|
|
|
/** \file
|
|
|
|
|
* \ingroup freestyle
|
2014-01-28 23:24:59 +09:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include "SceneHash.h"
|
|
|
|
|
|
2022-10-26 18:58:04 +02:00
|
|
|
#include "BLI_sys_types.h"
|
|
|
|
|
|
2014-10-05 00:29:09 +09:00
|
|
|
#include <sstream>
|
|
|
|
|
|
2014-01-28 23:24:59 +09:00
|
|
|
namespace Freestyle {
|
|
|
|
|
|
2014-10-05 00:29:09 +09:00
|
|
|
string SceneHash::toString()
|
|
|
|
|
{
|
2015-11-06 05:09:14 +11:00
|
|
|
stringstream ss;
|
|
|
|
|
ss << hex << _sum;
|
|
|
|
|
return ss.str();
|
2014-10-05 00:29:09 +09:00
|
|
|
}
|
|
|
|
|
|
2017-11-22 10:52:39 -02:00
|
|
|
void SceneHash::visitNodeViewLayer(NodeViewLayer &node)
|
2015-01-03 01:48:27 +09:00
|
|
|
{
|
2023-06-04 18:46:04 +10:00
|
|
|
RenderData *r = &node.scene().r;
|
2022-09-25 17:04:52 +10:00
|
|
|
adler32((uchar *)&r->xsch, sizeof(r->xsch)); // resolution_x
|
|
|
|
|
adler32((uchar *)&r->ysch, sizeof(r->ysch)); // resolution_y
|
|
|
|
|
adler32((uchar *)&r->size, sizeof(r->size)); // resolution_percentage
|
2015-02-02 09:17:16 +09:00
|
|
|
|
2023-06-04 18:46:04 +10:00
|
|
|
FreestyleConfig *config = &node.sceneLayer().freestyle_config;
|
2022-09-25 17:04:52 +10:00
|
|
|
adler32((uchar *)&config->flags, sizeof(config->flags));
|
|
|
|
|
adler32((uchar *)&config->crease_angle, sizeof(config->crease_angle));
|
|
|
|
|
adler32((uchar *)&config->sphere_radius, sizeof(config->sphere_radius));
|
|
|
|
|
adler32((uchar *)&config->dkr_epsilon, sizeof(config->dkr_epsilon));
|
2015-01-03 01:48:27 +09:00
|
|
|
}
|
|
|
|
|
|
2014-10-05 00:29:09 +09:00
|
|
|
void SceneHash::visitNodeCamera(NodeCamera &cam)
|
|
|
|
|
{
|
|
|
|
|
double *proj = cam.projectionMatrix();
|
|
|
|
|
for (int i = 0; i < 16; i++) {
|
2022-09-25 17:04:52 +10:00
|
|
|
adler32((uchar *)&proj[i], sizeof(double));
|
2014-10-05 00:29:09 +09:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2014-01-28 23:24:59 +09:00
|
|
|
void SceneHash::visitIndexedFaceSet(IndexedFaceSet &ifs)
|
|
|
|
|
{
|
2015-06-27 22:07:51 +09:00
|
|
|
const float *v = ifs.vertices();
|
2022-09-26 10:04:44 +10:00
|
|
|
const uint n = ifs.vsize();
|
2014-01-28 23:24:59 +09:00
|
|
|
|
2022-09-26 10:04:44 +10:00
|
|
|
for (uint i = 0; i < n; i++) {
|
2022-09-25 17:04:52 +10:00
|
|
|
adler32((uchar *)&v[i], sizeof(v[i]));
|
2014-10-05 00:29:09 +09:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static const int MOD_ADLER = 65521;
|
|
|
|
|
|
2022-09-25 17:04:52 +10:00
|
|
|
void SceneHash::adler32(const uchar *data, int size)
|
2014-10-05 00:29:09 +09:00
|
|
|
{
|
|
|
|
|
uint32_t sum1 = _sum & 0xffff;
|
|
|
|
|
uint32_t sum2 = (_sum >> 16) & 0xffff;
|
|
|
|
|
|
|
|
|
|
for (int i = 0; i < size; i++) {
|
|
|
|
|
sum1 = (sum1 + data[i]) % MOD_ADLER;
|
|
|
|
|
sum2 = (sum1 + sum2) % MOD_ADLER;
|
2014-01-28 23:24:59 +09:00
|
|
|
}
|
2014-10-05 00:29:09 +09:00
|
|
|
_sum = sum1 | (sum2 << 16);
|
2014-01-28 23:24:59 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} /* namespace Freestyle */
|