- void set_min_filter(TextureFilter);
- void set_mag_filter(TextureFilter);
- void set_wrap(TextureWrap);
- void set_wrap_s(TextureWrap);
- void set_wrap_t(TextureWrap);
- void set_wrap_r(TextureWrap);
- void set_generate_mipmap(bool);
- void set_compare_enabled(bool);
- void set_compare_func(Predicate);
+ Sampler &get_default_sampler() { return default_sampler; }
+ const Sampler &get_default_sampler() const { return default_sampler; }
+
+ DEPRECATED void set_min_filter(TextureFilter);
+ DEPRECATED void set_mag_filter(TextureFilter);
+
+ /** Sets filter for both minification and magnification. Since mipmapping
+ is not applicable to magnification, LINEAR is used instead. */
+ DEPRECATED void set_filter(TextureFilter);
+
+ DEPRECATED void set_mipmap_levels(unsigned) { }
+
+ DEPRECATED void set_max_anisotropy(float);
+
+ /** Sets the wrapping mode for all coordinates. */
+ DEPRECATED void set_wrap(TextureWrap);
+
+ DEPRECATED void set_wrap_s(TextureWrap);
+ DEPRECATED void set_wrap_t(TextureWrap);
+ DEPRECATED void set_wrap_r(TextureWrap);
+
+ static bool can_generate_mipmap();
+
+ void generate_mipmap();
+
+ /** Sets automatic mipmap generation. If enabled, mipmaps are generated
+ when a texture image is uploaded. */
+ void set_auto_generate_mipmap(bool);
+
+ /// Deprecated. Use set_auto_generate_mipmap instead.
+ DEPRECATED void set_generate_mipmap(bool g) { set_auto_generate_mipmap(g); }
+
+ /** Sets depth texture comparison. Has no effect on other formats. When
+ comparison is enabled, the third component of the texture coordinate is
+ compared against the texel value, and the result is returned as the texture
+ sample. */
+ DEPRECATED void set_compare_enabled(bool);
+
+ /** Sets the function to use for depth comparison. */
+ DEPRECATED void set_compare_func(Predicate);
+
+ /// Loads a Graphics::Image from a file and uploads it to the texture.
+ virtual void load_image(const std::string &, unsigned = 0);
+
+ DEPRECATED void load_image(const std::string &, bool srgb);
+
+ /** Uploads an image to the texture. If storage has not been defined, it
+ will be set to match the image. Otherwise the image must be compatible
+ with the defined storage. Semantics depend on the type of texture. */
+ virtual void image(const Graphics::Image &, unsigned = 0) = 0;
+
+ DEPRECATED void image(const Graphics::Image &, bool srgb);
+