Hi.
When scrolling to zoom in and out of the map, the aggregation point will occasionally be left unrendered on one layer. And the console reported no error. How can I solve this problem?
Use version: 4.17
code:
clusterPoint(points, layerName, icon, font, other) {
    const pointsArray = points && points.length > 0 ? JSON.parse(JSON.stringify(points)) : [];
    const id = Utils.uuid();
    layerName = layerName || id;
    let layer = this.getLayer(layerName);
    const zIndex = other && other.zIndex ? other.zIndex : 0;
    layer = !layer ? this.createGraphicsLayer(layerName, 'clusterPoint', zIndex) : layer;
    const defaultIcon = {
      url: SITE_CONFIG.host + '/libs/mapLib/icons/t1.png',
      clusterUrl: SITE_CONFIG.host + '/libs/mapLib/icons/markpoint_bg3.png',
      width: 20,
      height: 20,
    };
    icon = icon ? Object.assign(defaultIcon, icon) : defaultIcon;
    const defaultFont = {
      fontSize: '16px',
      color: '#fff',
      offset: [0, 0],
    };
    font = font ? Object.assign(defaultFont, font) : defaultFont;
    let simpleStyle = {
      bgColor: [255, 127, 80, 1], // 背景色
      borderColor: [255, 127, 80, 1], // 边框颜色
    }
    if (other && other.simpleStyle) simpleStyle = Object.assign(simpleStyle, other.simpleStyle)
    const textSymbol = {
      type: "text",
      color: font.color,
      font: {
        size: font.fontSize,
      },
      xoffset: 0,
      yoffset: 0,
    }
    const featureOptionsLabelingInfo = {
      labelsVisible: true,
      labelingInfo: [
        {
          symbol: textSymbol,
          labelPlacement: "center-center",
          deconflictionStrategy: 'none',
          labelExpressionInfo: {
            expression: `return $feature.text`
          },
        }
      ]
    }
 
    let labelingInfo = [
      {
        symbol: textSymbol,
        labelPlacement: "center-center",
        deconflictionStrategy: 'none',
        labelExpressionInfo: {
          expression: `
                    var label = Round($feature.cluster_avg_text * $feature.cluster_count); 
                    return label
                  `
        },
      },
    ];
    const clusterConfig = {
      type: "cluster",
      clusterRadius: 100,
      labelsVisible: true,
      popupEnabled: false,
      labelingInfo: labelingInfo,
      clusterMaxSize: '60px',
      clusterMinSize: '24px',
    };
    let renderer = {
      type: "class-breaks",
      field: 'cluster_count',
      valueExpression: `$feature.cluster_count`,
      visualVariables: [
        {
          type: "size",
          field: 'cluster_count',
          valueExpression: `$feature.cluster_count`,
          minDataValue: 1,
          maxDataValue: pointsArray.length,
          minSize: 36,
          maxSize: 60,
        }
      ],
      defaultSymbol: {
        type: 'picture-marker',
        url: icon.clusterUrl,
        width: icon.width,
        height: icon.height,
      },
      classBreakInfos: [
        // 合并数量$feature.cluster_count是1的时候展示的样式
        {
          minValue: 1,
          maxValue: 1,
          symbol: {
            type: 'picture-marker',
            url: icon.url,
            width: icon.width,
            height: icon.height,
            // xoffset: 0,
            // yoffset: 10,
          },
        },
      ],
    };
    let graphicPoints = [], fieldArr = [], textTotal = 0;
    for (let i = 0, len = pointsArray.length; i < len; i++) {
      let point = pointsArray[i]
      point.layerName = layerName;
      point.layer = layerName;
      point.pointId = point.pointId ? point.pointId : Utils.uuid();
      point.ObjectID = i;
      textTotal += point.text ? Number(point.text) : 0;
      if (i == 0) {
        fieldArr = Utils._getFields(point);
      }
      const geometry = new this.mapModules.Point({
        longitude: Number(point.lon),
        latitude: Number(point.lat),
        spatialReference: { wkid: dataWkid }
      })
      let graphic = new this.mapModules.Graphic({
        geometry: geometry,
        attributes: point,
        type: 'clusterPoint',
      })
      graphicPoints.push(graphic)
    }
    
    renderer.visualVariables[0].maxDataValue = textTotal;
    const featureOptions = {
      id: layerName,
      geometryType: "point",
      spatialReference: { wkid: dataWkid },
      source: graphicPoints,
      featureReduction: clusterConfig,
      objectIdField: 'ObjectID',
      typeIdField: 'text',
      popupEnabled: false,
      renderer: renderer,
      fields: fieldArr,
      outFields: ["*"]
    };
    featureOptions.labelsVisible = featureOptionsLabelingInfo.labelsVisible;
    featureOptions.labelingInfo = featureOptionsLabelingInfo.labelingInfo;
    let featureLayer = new this.mapModules.FeatureLayer(featureOptions);
    this.map.map.add(featureLayer)
    layer.add(graphicPoints)
  }
The effect
