0

我在 bixby 中使用缩略图卡在用户屏幕上显示多个选择。还添加了用于单击的插槽。我想要实现的是,如果用户单击缩略图,我应该获取特定卡片的 id 并对其进行处理以获取更多信息。这是布局

layout-macro-def (artist-thumbnail-card) {
params {
param (artistchoice) {
  type (ArtistChoiceResult)
  min (Required) max (One)
}
}
content {
thumbnail-card {
  image-position (Start)

  image-url ("#{value(artistchoice.multiple_image)}")
  title-area {
    halign (Start)
    slot1 {
      text {
        value ("#{value(artistchoice.multiple_name)}")
        style (Title_S)
      }
    }
    slot2 {
      single-line {
        text {
          value ("From #{value(artistchoice.multiple_cat)}")
          style (Detail_L_Soft)
        }
      }
    }
  }
  on-click {
    intent {
      goal: ArtistSearch
    }
  }
}
}
}

这是结果视图

result-view {
  match: ArtistChoiceResult (artistchoice) {
    from-output: ArtistChoice
  }

  message {
    template ("Please select one of the following")
  }

  render {
    if (size(artistchoice) > 1) {
     list-of (artistchoice) {
       has-details (true)
       where-each (item) {
         layout-macro (artist-thumbnail-card) {
         param (artistchoice) {
           expression (item)
        }
      }
    }
  }
} else-if (size(artistchoice) == 1) {
  layout-match (artistchoice) {
    mode (Details)
  }
}
}
}

我无法将 ID 信息发送到 ArtistSearch Intent。我将如何实现这一目标。而且我在其他变量中有 Id,那么我如何传递该值?

4

1 回答 1

0

根据您提供的代码,我们必须假设两件事:1)这是为artistchoice结构触发的结果视图 2)这multiple_name是一个包含所有选项的数组。

鉴于上述假设,您需要构建一个布局,其中multiple_name( multiple_name[1]multiple_name[2]multiple_name[3]等) 的每个元素都包含在其中。

由于无法使用可变点击事件定义一个点击事件,因此您需要为每个多选选项创建单独的卡片,以便每张卡片有一个点击事件。这将允许点击如下所示:

on-click {
    intent {
      goal: ArtistSearch
      value-set: [YOUR CONCEPT HERE]{$expr(artistchoice.multiple_name[1])}
    }
  }

如果您需要任何进一步的信息,请联系支持团队,我们可以讨论您面临的任何特定问题,这些问题可能是您的用例所独有的。

于 2019-02-08T21:47:46.773 回答