npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

troila-gl

v1.2.6-experimental.10

Published

Based on Three.js. Project for WebGL

Downloads

25

Readme

TGL

Based on Three.js. Project for WebGL

Install

yarn add troila-gl

Use

initial

import { App } from "troila-gl"

const app = new App({ appId: 'id', domain: 'server address' })

| Params | Type | Description | Optional | | -- | -- | -- | -- | | appId | string | 项目 id | true | domain | string | 服务端域名 | true | container | HTMLElement | 容器 Dom | false

Property

| Prop | Type | Default | Description | | -------------- | -------- | ---------- | ---- | | skyBox | menu | null | 天空盒 | fog | { color: string, density: number } | null | 雾化 | level | SceneLevel | SceneLevel | 层级实例 | widget | {Panel} | - | 创建锚点可选的组件

Method

on( type , func )

  • type {string} 事件类型
  • func {Function} 响应事件
  • returns {Function} 移除响应事件

| Type| Event Function Params | Description | | -- | -- | -- | -- | | onLoad | undefined |
| click | BaseObject | 行为对象
| dblclick | BaseObject | 行为对象
| mousemove | BaseObject | 行为对象
| mouseon | BaseObject | 行为对象
| mouseoff | BaseObject | 行为对象

app.on('onLoad', () => {
    
})
app.on('click', (obj) => {
    
})

query(str)

查询 id 为 001 的对象集合 app.query('#001') 查询 name 为 car01 的对象集合 app.query('car01') 查询 type 为 Thing 的对象集合 app.query('.Thing') 根据正则表达式匹配 name 中包含 'car' 的子物体 app.query(/car/)

  • str {string | RegExp} 查询规则
  • returns {BaseObject[]} 查询结果

createUIAnchor({ element, parent, localPosition?, pivot?, pivotPixel?, node?})

将界面元素的 dom 节点挂接在 3D 场景中某个位置或物体上

@param element - 界面的dom元素
@param parent - 界面的父物体(位置跟随父物体更新)
@param localPosition - 相对父物体的偏移系数
@param pivot - 界面的轴心,以百分比表示界面轴心位置, [0,0]即以界面左上角定位,[1,1]即以界面右下角进行定位
@param pivotPixel - 相对于Element轴心点的偏移像素值
@param node - 适用于非BaseObject的节点挂载
已经提供了 widget.Panel,Panel的优点是 统一的样式 和 响应数据更改自动更新界面. 系统化的样式建议直接使用 Panel
@returns 界面元素实例
const element = document.createElement('div')
element.textContent = 'div'
app.createUIAnchor({ element, parent: baseObject })

widget

  • Panel

基础展示面板

const element = document.createElement('div')
element.textContent = 'div'
const panel = new app.widget.Panel({ width: '100px', height: '100px' })
panel.container.style.backgroundColor = '#999999'
panel.appendChild(element)
app.createUIAnchor({ element: panel.domElement, parent: baseObject })

Panel

| Prop | Type | Default | Description | | -------------- | -------- | ---------- | ---- | | domElement | HTMLElement | div | dom

addString( object, property )

  • object {Object} 数据对象
  • property {String} 要绑定的某属性值的属性名称
  • returns {PanelString}
const dataObj = {
  '气温':'21℃'
}
const ctrl = panel.addString(dataObj, '气温')

添加字符串组件

appendChild( node )

  • node {HTMLElement} 添加到Child的HTML
panel.appendChild(document.createElement('div'))

添加HTML

SceneLevel

Method

change( target )

  • target {BaseObject} 跳转到的目标对象

切换层级行为

back()

回退层级行为

popToTop()

返回顶层

rollback()

回滚层级

level property

| Prop | Type | Default | Description | | -------------- | -------- | ---------- | ---- | | current | BaseObject | null | null | 当前层级 | root | BaseObject | RootLevel | 根结点

BaseObject

Method

toScreenPosition ( )

  • returns { x: number; y: number; } 相对于container的2d坐标

on ( event , func )

  • event {EventType} 事件类型
  • func {Function} 响应事件
  • returns {Function} 移除响应事件

off ( event , func? )

  • event {EventType} 事件类型
  • func {Function} 响应事件,不传时清除事件下的所有响应

Property

| Prop | Type | Default | Description | | -------------- | -------- | ---------- | ---- | | visible | boolean | true | 显示 | selected | boolean | false | 选中 | style | BaseStyle | BaseStyle | 样式

BaseStyle Property

| Prop | Type | Default | Description | | -------------- | -------- | ---------- | ---- | | opacity | number | 1.0 | 透明度