UNPKG

molstar

Version:

A comprehensive macromolecular library.

59 lines 3.03 kB
/** * Copyright (c) 2019 mol* contributors, licensed under MIT, See LICENSE file for more info. * * @author Alexander Rose <alexander.rose@weirdbyte.de> */ import { __assign } from "tslib"; import './index.html'; import { Canvas3D, Canvas3DContext } from '../../mol-canvas3d/canvas3d'; import { TextBuilder } from '../../mol-geo/geometry/text/text-builder'; import { Text } from '../../mol-geo/geometry/text/text'; import { ParamDefinition, ParamDefinition as PD } from '../../mol-util/param-definition'; import { Color } from '../../mol-util/color'; import { Representation } from '../../mol-repr/representation'; import { SpheresBuilder } from '../../mol-geo/geometry/spheres/spheres-builder'; import { createRenderObject } from '../../mol-gl/render-object'; import { Spheres } from '../../mol-geo/geometry/spheres/spheres'; import { resizeCanvas } from '../../mol-canvas3d/util'; var parent = document.getElementById('app'); parent.style.width = '100%'; parent.style.height = '100%'; var canvas = document.createElement('canvas'); parent.appendChild(canvas); resizeCanvas(canvas, parent); var canvas3d = Canvas3D.create(Canvas3DContext.fromCanvas(canvas)); canvas3d.animate(); function textRepr() { var props = __assign(__assign({}, PD.getDefaultValues(Text.Params)), { attachment: 'top-right', fontQuality: 3, fontWeight: 'normal', borderWidth: 0.3, background: true, backgroundOpacity: 0.5, tether: true, tetherLength: 1.5, tetherBaseWidth: 0.5 }); var textBuilder = TextBuilder.create(props, 1, 1); textBuilder.add('Hello world', 0, 0, 0, 1, 1, 0); // textBuilder.add('Добрый день', 0, 1, 0, 0, 0) // textBuilder.add('美好的一天', 0, 2, 0, 0, 0) // textBuilder.add('¿Cómo estás?', 0, -1, 0, 0, 0) // textBuilder.add('αβγ Å', 0, -2, 0, 0, 0) var text = textBuilder.getText(); var values = Text.Utils.createValuesSimple(text, props, Color(0xFFDD00), 1); var state = Text.Utils.createRenderableState(props); var renderObject = createRenderObject('text', values, state, -1); console.log('text', renderObject, props); var repr = Representation.fromRenderObject('text', renderObject); return repr; } function spheresRepr() { var spheresBuilder = SpheresBuilder.create(1, 1); spheresBuilder.add(0, 0, 0, 0); spheresBuilder.add(5, 0, 0, 0); spheresBuilder.add(-4, 1, 0, 0); var spheres = spheresBuilder.getSpheres(); var props = ParamDefinition.getDefaultValues(Spheres.Utils.Params); var values = Spheres.Utils.createValuesSimple(spheres, props, Color(0xFF0000), 0.2); var state = Spheres.Utils.createRenderableState(props); var renderObject = createRenderObject('spheres', values, state, -1); console.log('spheres', renderObject); var repr = Representation.fromRenderObject('spheres', renderObject); return repr; } canvas3d.add(textRepr()); canvas3d.add(spheresRepr()); canvas3d.requestCameraReset(); //# sourceMappingURL=render-text.js.map