繁体   English   中英

Carousel Card在Facebook Messenger的BotFramework中无法正常运行

[英]Carousel Card is not working well in BotFramework for Facebook Messenger

我实现了一个机器人,该机器人将英雄卡发送给用户作为响应。 如我所料,以下代码将轮播发送到Messenger。

ConnectorClient connector = new ConnectorClient(new Uri(activity.ServiceUrl));

#region HeroCard
Activity replyToConversation = activity.CreateReply("Should go to conversation, with a hero card");
replyToConversation.Recipient = activity.From;
replyToConversation.Type = "message";
replyToConversation.Attachments = new List<Attachment>();
List<CardImage> cardImages = new List<CardImage>();
cardImages.Add(new CardImage(url: "https://upload.wikimedia.org/wikipedia/en/a/a6/Bender_Rodriguez.png"));
cardImages.Add(new CardImage(url: "https://upload.wikimedia.org/wikipedia/en/archive/a/a9/20151112035044!Banyan_Tree_(_Shiv_Bajrang_Dham_Kishunpur).jpeg"));
List<CardAction> cardButtons = new List<CardAction>();
CardAction plButton = new CardAction()
{
    Value = "https://en.wikipedia.org/wiki/Pig_Latin",
    Type = "openUrl",
    Title = "WikiPedia Page"
};
CardAction plButton2 = new CardAction()
{
    Value = "https://en.wikipedia.org/wiki/Pig_Latin",
    Type = "openUrl",
    Title = "WikiPedia Page"
};
cardButtons.Add(plButton);
cardButtons.Add(plButton2);
HeroCard plCard = new HeroCard()
{
    Title = "I'm a hero card",
    Subtitle = "Pig Latin Wikipedia Page",
    Images = cardImages,
    Buttons = cardButtons
};
Attachment plAttachment = plCard.ToAttachment();
replyToConversation.Attachments.Add(plAttachment);
var reply = await connector.Conversations.SendToConversationAsync(replyToConversation);
#endregion

但是,我收到以下消息,它不是轮播。 在此处输入图片说明

问题是如何使用botframework的本地变量(不使用手动生成的json)将轮播发送到Facebook Messenger?

这些更改解决了该问题:

  • 首先,创建两张卡片和附件
  • 其次,将AttachmentLayout设置为"carousel"

您可以在以下位置找到修改后的代码:

ConnectorClient connector = new ConnectorClient(new Uri(activity.ServiceUrl));

#region HeroCard

Activity replyToConversation = activity.CreateReply("Should go to conversation, with a hero card");
replyToConversation.Recipient = activity.From;
replyToConversation.Type = "message";
replyToConversation.Attachments = new List<Attachment>();
// First Change
// Card #One
List<CardImage> cardImages1 = new List<CardImage>();
cardImages1.Add(new CardImage(url: "https://upload.wikimedia.org/wikipedia/en/a/a6/Bender_Rodriguez.png"));

List<CardAction> cardButtons1 = new List<CardAction>();
CardAction plButton1 = new CardAction()
{
    Value = "https://en.wikipedia.org/wiki/Pig_Latin",
    Type = "openUrl",
    Title = "WikiPedia Page"
};
cardButtons1.Add(plButton1);
HeroCard plCard1 = new HeroCard()
{
    Title = "I'm a hero card",
    Subtitle = "Pig Latin Wikipedia Page",
    Images = cardImages1,
    Buttons = cardButtons1
};
Attachment plAttachment1 = plCard1.ToAttachment();
replyToConversation.Attachments.Add(plAttachment1);

// Card #Two
List<CardImage> cardImages2 = new List<CardImage>();
cardImages2.Add(new CardImage(url: "https://upload.wikimedia.org/wikipedia/en/archive/a/a9/20151112035044!Banyan_Tree_(_Shiv_Bajrang_Dham_Kishunpur).jpeg"));

List<CardAction> cardButtons2 = new List<CardAction>();
CardAction plButton2 = new CardAction()
{
    Value = "https://en.wikipedia.org/wiki/Pig_Latin",
    Type = "openUrl",
    Title = "WikiPedia Page"
};
cardButtons2.Add(plButton2);
HeroCard plCard2 = new HeroCard()
{
    Title = "I'm a hero card",
    Subtitle = "Pig Latin Wikipedia Page",
    Images = cardImages2,
    Buttons = cardButtons2
};

Attachment plAttachment2 = plCard2.ToAttachment();
replyToConversation.Attachments.Add(plAttachment2);

// Second Change
replyToConversation.AttachmentLayout = "carousel";

var reply = await connector.Conversations.SendToConversationAsync(replyToConversation);
#endregion

您可以在下面的Facebook Messenger中找到该轮播的图片: 在此处输入图片说明

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM