首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Jointjs petri-net图标记不能渲染!我能做些什么?

Jointjs petri-net图标记不能渲染!我能做些什么?
EN

Stack Overflow用户
提问于 2021-11-22 16:56:54
回答 1查看 30关注 0票数 0

目前,我正在尝试将Petrinet生成器设置为jupyter小部件。因此,我使用cookiecutter-ts-widget模板,这意味着我在typescript中实现前端逻辑。我对这个过程很满意,除了我所在位置的令牌没有被渲染外,一切都很好。

下面是我如何在joint.dia.Paper上创建一个示例

代码语言:javascript
复制
PetriView.graph = new joint.dia.Graph();
PetriView.pn = joint.shapes.pn;
PetriView.paper = new joint.dia.Paper({
      el: document.createElement("div"),
      width: this.width,
      height: this.height,
      gridSize: PetriView.gridSize,
      defaultAnchor: { name: 'perpendicular' },
      defaultConnectionPoint: { name: 'boundary' },
      model: PetriView.graph,
      linkPinning: false,                             // prevent dangling links
      interactive: function() { return true },        // make cells draggable
    });

private firstExample() {
    this.clearAll();

    // Define Places
    var pReady = new PetriView.pn.Place({
        position: { x: 140, y: 50 },
        attrs: {
            '.label': {
                'text': 'ready',
                'fill': '#7c68fc' },
            '.root': {
                'stroke': '#7c68fc',
                'stroke-width': 3,
            },
            '.alot > text': {
                'fill': '#fe854c',
                'font-family': 'Courier New',
                'font-size': 20,
                'font-weight': 'bold',
                'ref-x': 0.5,
                'ref-y': 0.5,
                'y-alignment': -0.5,
                'transform': null as any
            },
            '.tokens > circle': {
                'fill': '#7a7e9b'
            }
        },
        'tokens': 1,
    });

    var pIdle = pReady.clone()
        .attr('.label/text', 'idle')
        .position(140, 260)
        .set('tokens', 2);

    *[...]*

    // Define Transitions
    var tProduce = new PetriView.pn.Transition({
        size: { width: 30, height: 40 },
        position: { x: 50, y: 160 },
        attrs: {
            '.label': {
                'text': 'produce',
                'fill': '#fe854f'
            },
            '.root': {
                'fill': '#9586fd',
                'stroke': '#7c68fc'
            },
            'rect': {
                width: 12,
                height: 50,
                fill: '#000000',
                stroke: '#000000',
                "stroke-width": 3,
            },
        }
    });

    var tSend = tProduce.clone()
        .attr('.label/text', 'send')
        .position(270, 160);

    *[...]*

    // add cells to graph and create links
    PetriView.graph.addCell([pReady, pIdle, buffer, cAccepted, cReady, tProduce, tSend, tAccept, tConsume]);
    PetriView.graph.addCell([
      PetriView.link(tProduce, pReady), PetriView.link(pReady, tSend), PetriView.link(tSend, pIdle), PetriView.link(pIdle, tProduce), 
      PetriView.link(tSend, buffer), PetriView.link(buffer, tAccept), PetriView.link(tAccept, cAccepted), 
      PetriView.link(cAccepted, tConsume), PetriView.link(tConsume, cReady), PetriView.link(cReady, tAccept)
    ]);

    return PetriView.graph
  }

通过控制台日志记录,您可以看到令牌在各自的单元格中(例如tokens: 1),但即使整个图呈现得很好,也不会呈现。此外,我注意到pn.Place单元格只包含以下标志:{PORTS: 16, RENDER: 64, RESIZE: 8, ROTATE: 32, TOOLS: 4, TRANSLATE: 2, UPDATE: 1}

根据我的理解,还应该有一个TOKENS标志,它被选中,最后在后台以动态HTML的形式添加令牌。

包含标记的单元格的正确示例:

代码语言:javascript
复制
  <circle class="root" id="v-8" r="25" fill="#ffffff" stroke="#7c68fc"   transform="translate(25, 25)" stroke-width="3"></circle>
  <g class="tokens two">
    <circle id="v-10" fill="#7a7e9b" r="5" transform="translate(19, 25)"></circle>
    <circle id="v-11" fill="#7a7e9b" r="5" transform="translate(31, 25)"></circle>
  </g>

与我的单元格(包含未呈现的标记):

代码语言:javascript
复制
<circle class="root" id="v-7" r="25" fill="#ffffff" stroke="red" transform="translate(25, 25)" stroke-width="3"></circle>
<g class="tokens"></g>

有没有人知道如何让一个新位置(即new pn.Place())的初始化器在内部添加一个TOKENS-flag?或者,你知道我如何自己添加这个标志吗?

如有任何帮助,我们将不胜感激!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-11-23 14:45:37

实际上,在他们的GitHub上发布了这个问题后,我收到了一个答案,结果证明是解决方案。您需要指定图形的cellNamespace和纸张对象的cellViewNamespace。

查看此处:https://github.com/clientIO/joint/issues/1579

代码语言:javascript
复制
const namespace = joint.shapes; // e.g. { standard: { Rectangle: RectangleElementClass }}
const graph = new joint.dia.Graph({ /* attributes of the graph */ }, { cellNamespace: namespace });
const paper = new joint.dia.Paper({ cellViewNamespace: namespace });

正如kumilingus所指出的,这个问题应该通过强制命名空间的方式在jointjs v4的发布中得到解决。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70069578

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档