Как экспортировать диаграммы, которые динамически генерируются с помощью jquery flot в Excel, используя C # в asp.net?

0

У меня есть страница aspx, которая генерирует диаграммы с помощью jQuery flot tool. Его работа хорошая. Мое новое требование - разместить на этой странице кнопку "Экспорт в Excel". Всякий раз, когда я нажимаю эту кнопку, диаграммы, которые генерируются инструментом flQ jQuery, должны экспортировать в файл excel в виде изображений. Его как копировать и вставлять изображение с html-страницы в файл excel. Я пробовал так много способов, но я не могу найти правильное решение. Помогите мне решить эту проблему.

метод 1: 1.В JavaScript я преобразовываю диаграмму div в холст и устанавливаю источник управления имиджем asp в это изображение. Его отображение в браузере, как ожидалось.

var data = canvas.toDataURL('image/jpg'); 
document.getElementById('ctl00_ctl00_ContentPlaceHolder1_ContentPlaceHolder1_imgChart').src=data;         
}
});

2.Но на сервере я не могу получить доступ к этому изображению src, даже если я положил кнопку отправки на панели обновления.

string picName = imgChart.ImageUrl;
worksheet.Shapes.AddPicture(picName, Microsoft.Office.Core.MsoTriState.msoFalse, Microsoft.Office.Core.MsoTriState.msoCTrue, 10, 10, 100, 100);

Он показывает, что picName является пустой ошибкой.

метод 2:

  1. Преобразование диаграммы в изображение и сохранение в локальной папке
  2. Добавьте файл изображения из папки в excel

Но проблема не в том, чтобы преобразовать диаграмму в изображение и сохранить в локальной папке.

  • 0
    Не могли бы вы опубликовать соответствующий код, что вы уже пробовали
Теги:
excel

1 ответ

2
Лучший ответ

Такое поведение ожидается в ASP.NET. Изменение пути src (например, свойство ImageUrl) с JavaScript изображения не будет доступно в обратной передаче.

Я попытался бы сохранить значение canvas также в HiddenField и взять значение оттуда в моем коде на стороне сервера.

JavaScript

var data = canvas.toDataURL('image/jpg'); 
document.getElementById('ctl00_ctl00_ContentPlaceHolder1_ContentPlaceHolder1_imgChart').src=data;
document.getElementById('ctl00_ctl00_ContentPlaceHolder1_ContentPlaceHolder1_HiddenField1').value=data;

С#

string picName = HiddenField1.Value;
worksheet.Shapes.AddPicture(picName, Microsoft.Office.Core.MsoTriState.msoFalse, Microsoft.Office.Core.MsoTriState.msoCTrue, 10, 10, 100, 100);

Обновление: этот подход даст вам данные: URL-адрес, который будет выглядеть следующим образом .

Чтобы сохранить эту строку как образ в С#, вам нужен следующий код, который я нашел здесь. После сохранения этого изображения в файловой системе (файл "~/temp/file.png") вы можете легко добавить его в excel.

С#

string data = @"";

         var base64Data = Regex.Match(data, @"data:image/(?<type>.+?),(?<data>.+)").Groups["data"].Value;
         var binData = Convert.FromBase64String(base64Data);

         using (var stream = new MemoryStream(binData))
         {
             System.Drawing.Image image = new Bitmap(stream);

             image.Save(Server.MapPath("~/temp/file.png"));
         }
  • 0
    спасибо .. но мы не можем хранить холст в скрытом поле правильно ?? Bcs на стороне сервера, значение будет обрабатываться только как строка, а не как путь к изображению или файлу.
  • 0
    В вашем коде вы читаете свойство ImageUrl, которое также является строкой. В конечном итоге вы получите значение data: URL в формате png. Например, вы получите строку, которая будет выглядеть следующим образом: «data: image / png; base64, iVBORw0KGgoAAAANSUhEUgAAADIA ...»
Показать ещё 3 комментария

Ещё вопросы

Сообщество Overcoder
Наверх
Меню