This repository has been archived on 2023-10-09. You can view files and clone it, but cannot push or open issues or pull requests.
Files
blender-archive/source/blender/render/RE_texture.h

164 lines
4.8 KiB
C++

/*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
* The Original Code is Copyright (C) 2006 by Blender Foundation
* All rights reserved.
*/
/** \file
* \ingroup render
*
* This include is for non-render pipeline exports (still old cruft here).
*/
#pragma once
#include "BLI_compiler_attrs.h"
/* called by meshtools */
struct Depsgraph;
struct ImagePool;
struct MTex;
struct Tex;
#ifdef __cplusplus
extern "C" {
#endif
/* texture_procedural.c */
/**
* \param pool: Thread pool, may be NULL.
*
* \return True if the texture has color, otherwise false.
*/
bool RE_texture_evaluate(const struct MTex *mtex,
const float vec[3],
int thread,
struct ImagePool *pool,
bool skip_load_image,
bool texnode_preview,
/* Return arguments. */
float *r_intensity,
float r_rgba[4]) ATTR_NONNULL(1, 2, 7, 8);
/**
* \param in: Destination
* \param tex: Texture.
* \param out: Previous color.
* \param fact: Texture strength.
* \param facg: Button strength value.
*/
void texture_rgb_blend(
float in[3], const float tex[3], const float out[3], float fact, float facg, int blendtype);
float texture_value_blend(float tex, float out, float fact, float facg, int blendtype);
void RE_texture_rng_init(void);
void RE_texture_rng_exit(void);
/* texture_image.c */
void ibuf_sample(struct ImBuf *ibuf, float fx, float fy, float dx, float dy, float result[4]);
/* texture_pointdensity.c */
struct PointDensity;
void RE_point_density_cache(struct Depsgraph *depsgraph, struct PointDensity *pd);
void RE_point_density_minmax(struct Depsgraph *depsgraph,
struct PointDensity *pd,
float r_min[3],
float r_max[3]);
/**
* \note Requires #RE_point_density_cache() to be called first.
* \note Frees point density structure after sampling.
*/
void RE_point_density_sample(struct Depsgraph *depsgraph,
struct PointDensity *pd,
int resolution,
float *values);
void RE_point_density_free(struct PointDensity *pd);
void RE_point_density_fix_linking(void);
/* texture_procedural.c */
/**
* Texture evaluation result.
*/
typedef struct TexResult {
float tin;
float trgba[4];
/* Is acually a bool true->use alpha, false->set alpha to 1.0. */
int talpha;
float *nor;
} TexResult;
/* This one uses nodes. */
/**
* \warning if the texres's values are not declared zero,
* check the return value to be sure the color values are set before using the r/g/b values,
* otherwise you may use uninitialized values - Campbell
*
* Use it for stuff which is out of render pipeline.
*/
int multitex_ext(struct Tex *tex,
float texvec[3],
float dxt[3],
float dyt[3],
int osatex,
struct TexResult *texres,
short thread,
struct ImagePool *pool,
bool scene_color_manage,
bool skip_load_image);
/**
* Nodes disabled.
* extern-tex doesn't support nodes (#ntreeBeginExec() can't be called when rendering is going on).
*
* Use it for stuff which is out of render pipeline.
*/
int multitex_ext_safe(struct Tex *tex,
const float texvec[3],
struct TexResult *texres,
struct ImagePool *pool,
bool scene_color_manage,
bool skip_load_image);
/**
* Only for internal node usage.
*
* this is called from the shader and texture nodes
* Use it from render pipeline only!
*/
int multitex_nodes(struct Tex *tex,
const float texvec[3],
float dxt[3],
float dyt[3],
int osatex,
struct TexResult *texres,
short thread,
short which_output,
struct MTex *mtex,
struct ImagePool *pool);
#ifdef __cplusplus
}
#endif