droid_wrap/android/
renderscript.rs

1/*
2 * Copyright (c) 2024. The RigelA open source project team and
3 * its contributors reserve all rights.
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
9 * Unless required by applicable law or agreed to in writing, software distributed under the
10 * License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11 * See the License for the specific language governing permissions and limitations under the License.
12 */
13
14#![allow(deprecated)]
15
16
17use crate::{JType,JObjRef,JObjNew};
18use droid_wrap_derive::java_class;
19
20
21//noinspection SpellCheckingInspection
22/**
23此类提供将数据传递到 RenderScript 内核和从 RenderScript 内核传递数据的主要方法。Allocation 为给定类型提供后备存储。
24Allocation 还包含一组使用标志,用于指示如何使用 Allocation。例如,Allocation 可能具有使用标志,指定它既可以从脚本中使用,也可以作为 Sampler 的输入。
25开发人员必须使用 syncAll 同步这些不同的用法,以确保 Allocation 的不同用户对内存具有一致的视图。例如,如果将 Allocation 用作一个内核的输出,并将其用作后续内核的 Sampler 输入,则开发人员必须在启动第二个内核之前调用 syncAll(Allocation.USAGE_SCRIPT) 以确保正确性。
26Allocation 可以使用 copyFrom 例程填充。对于更复杂的 Element 类型,可以使用 copyFromUnchecked 方法从字节数组或类似构造中复制。
27
28开发人员指南
29有关创建使用 RenderScript 的应用程序的更多信息,请阅读 RenderScript 开发人员指南。
30*/
31#[deprecated(note = "Renderscript 已在 API 级别 31 中弃用。请参阅迁移指南了解建议的替代方案。")]
32#[java_class(name = "android/renderscript/Allocation")]
33pub struct Allocation;
34
35
36//noinspection SpellCheckingInspection
37/**
38此类提供对 RenderScript 上下文的访问,该上下文控制 RenderScript 初始化、资源管理和拆卸。必须先创建 RenderScript 类的实例,然后才能创建任何其他 RS 对象。
39
40开发者指南
41有关创建使用 RenderScript 的应用程序的更多信息,请阅读 RenderScript 开发者指南。
42*/
43#[deprecated(note = "Renderscript 已在 API 级别 31 中弃用。请参阅迁移指南以了解建议的替代方案。")]
44#[java_class(name = "android/renderscript/RenderScript")]
45pub struct RenderScript;