【问题标题】:Carousel Card is not working well in BotFramework for Facebook Messenger轮播卡在 Facebook Messenger 的 BotFramework 中无法正常工作
【发布时间】:2017-02-14 19:45:21
【问题描述】:

我已经实现了一个机器人,它会向用户发送一张英雄卡片作为响应。 正如我所料,以下代码将轮播发送给信使。

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 发送轮播?

【问题讨论】:

    标签: c# carousel botframework facebook-messenger-bot


    【解决方案1】:

    这些更改解决了问题:

    • 首先,创建两张卡片和附件
    • 其次,将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 中找到轮播图:

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2018-08-17
      • 2017-12-30
      • 2016-03-16
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多