用于加载 `.pdb` 资源的加载器。
[link:http://en.wikipedia.org/wiki/Protein_Data_Bank_(file_format) 蛋白质数据库] 文件格式是描述分子三维结构的文本文件。
[name] 是一个附加组件,必须显式导入。请参阅 [link:#manual/introduction/Installation Installation / Addons]。
import { PDBLoader } from 'three/addons/loaders/PDBLoader.js';
// instantiate a loader
const loader = new PDBLoader();
// load a PDB resource
loader.load(
// resource URL
'models/pdb/caffeine.pdb',
// called when the resource is loaded
function ( pdb ) {
const geometryAtoms = pdb.geometryAtoms;
const geometryBonds = pdb.geometryBonds;
const json = pdb.json;
console.log( 'This molecule has ' + json.atoms.length + ' atoms' );
},
// called when loading is in progresses
function ( xhr ) {
console.log( ( xhr.loaded / xhr.total * 100 ) + '% loaded' );
},
// called when loading has errors
function ( error ) {
console.log( 'An error happened' );
}
);
[example:webgl_loader_pdb]
[page:LoadingManager manager] — 加载器使用的 [page:LoadingManager loadingManager] 。默认值为 [page:LoadingManager THREE.DefaultLoadingManager]。
创建一个新的 [name]。
有关公共属性,请参阅 [page:Loader] 基类。
有关常用方法,请参阅 [page:Loader] 基类。
[page:String url] — 包含 `.pdb` 文件路径/URL 的字符串。
[page:Function onLoad] — (可选)加载成功完成后调用的函数。该函数接收具有以下属性的对象。[page:BufferGeometry geometryAtoms]、[page:BufferGeometry
geometryBonds] 和 [page:Object JSON] 结构。
[page:Function onProgress] — (可选)加载过程中调用的函数。参数将是 XMLHttpRequest 实例,其中包含 .[page:Integer total] 和 .[page:Integer
loaded] 字节。如果服务器没有设置 Content-Length,.[page:Integer total] 将为 0。
[page:Function onError] —(可选)加载期间发生错误时调用的函数。该函数接收错误作为参数。
开始从 url 加载并使用解析后的响应内容调用 onLoad。
[page:String text] — 要解析的文本 `pdb` 结构。
解析 `pdb` 文本并返回JSON结构。
[link:https://github.com/mrdoob/three.js/blob/master/examples/jsm/loaders/PDBLoader.js examples/jsm/loaders/PDBLoader.js]