Хобрук: Ваш путь к мастерству в программировании

С# Пользовательский цвет круговой диаграммы Excel

Как создать собственный цвет на моей круговой диаграмме Excel? Моя круговая диаграмма имеет 5 срезов. Ниже мой исходный код.

using Excel = Microsoft.Office.Interop.Excel;
Excel.Range chartRange;

Excel.ChartObjects xlCharts = (Excel.ChartObjects)xlWorkSheet.ChartObjects(Type.Missing);
Excel.ChartObject myChart = (Excel.ChartObject)xlCharts.Add(10, 80, 500, 350);
Excel.Chart chartPage = myChart.Chart;

chartRange = xlWorkSheet.get_Range("A3", "B7");            
chartPage.ChartStyle = 209;
chartPage.HasTitle = true;
chartPage.ChartTitle.Text = "HeaderText Title";
chartPage.SetSourceData(chartRange, misValue);            
chartPage.ChartType = Excel.XlChartType.xl3DPieExploded;
chartPage.Elevation = 35;
chartPage.ApplyDataLabels(Excel.XlDataLabelsType.xlDataLabelsShowLabelAndPercent ,false, true, true, false, true, false, true, true, Separator:System.Environment.NewLine);

xlWorkBook.SaveAs(saveAsLocation);
xlWorkBook.Close(true, misValue, misValue);
xlApp.Quit();
15.08.2017

  • ЛУЧШИЙ совет, который кто-то может вам дать, это не обязательно рыба, а то, как преобразовать записанный макрос в C#, чтобы рыбачить на всю жизнь: blogs.msdn.microsoft.com/csharpfaq/2010/09/27/ 15.08.2017

Ответы:


1

Вы можете изменить ColorIndex каждой точки круговой диаграммы следующим образом:

var series = (Excel.SeriesCollection)chartPage.SeriesCollection();
series.Item(1).Points(1).Interior.ColorIndex = 3; //Red
series.Item(1).Points(2).Interior.ColorIndex = 4; //Green
series.Item(1).Points(3).Interior.ColorIndex = 5; //Blue
series.Item(1).Points(4).Interior.ColorIndex = 6; //Yellow
series.Item(1).Points(5).Interior.ColorIndex = 7; //Magenta

Вот полный список доступных цветов msdn

Свойство ColorIndex может иметь допустимые целочисленные аргументы от 0 до 56, которые генерируют цвет.

15.08.2017

2

Я считаю, что вы можете изменить свойство ForeColor в формате точек серии. Что-то типа:

var series = (Excel.SeriesCollection)chartPage.SeriesCollection();
var points = (Excel.Points)series.Item(1).Points();
points.Item(1).Format.Fill.ForeColor.RGB = (int)Excel.XlRgbColor.rgbRed;
points.Item(2).Format.Fill.ForeColor.RGB = (int)Excel.XlRgbColor.rgbBlue;

...и так далее.

15.08.2017
  • Просто будьте осторожны с рекламой двойных точек в Interop. Вот пара из сообщений в теме. 15.08.2017
  • Новые материалы

    Создание кнопочного меню с использованием HTML, CSS и JavaScript
    Вы будете создавать кнопочное меню, которое имеет состояние наведения, а также позволяет вам выбирать кнопку при нажатии на нее. Финальный проект можно увидеть в этом Codepen . Шаг 1..

    Внедрите OAuth в свои веб-приложения для повышения безопасности
    OAuth — это широко распространенный стандарт авторизации, который позволяет приложениям получать доступ к ресурсам от имени пользователя, не раскрывая его пароль. Это позволяет пользователям..

    Классы в JavaScript
    class является образцом java Script Object. Конструкция «class» позволяет определять классы на основе прототипов с чистым, красивым синтаксисом. // define class Human class Human {..

    Как свинг-трейдеры могут использовать ИИ для больших выигрышей
    По мере того как все больше и больше профессиональных трейдеров и активных розничных трейдеров узнают о возможностях, которые предоставляет искусственный интеллект и машинное обучение для улучшения..

    Как построить любой стол
    Я разработчик программного обеспечения. Я люблю делать вещи и всегда любил. Для меня программирование всегда было способом создавать вещи, используя только компьютер и мое воображение...

    Обзор: Машинное обучение: классификация
    Только что закончил третий курс курса 4 часть специализации по машинному обучению . Как и второй курс, он был посвящен низкоуровневой работе алгоритмов машинного обучения. Что касается..

    Разработка расширений Qlik Sense с qExt
    Использование современных инструментов веб-разработки для разработки крутых расширений Вы когда-нибудь хотели кнопку для установки переменной в приложении Qlik Sense? Когда-нибудь просили..