2015-09-04 11 views
9

Począwszy od przykładowego filtra crossfilter płatności (https://github.com/square/crossfilter/wiki/API-Reference) w jaki sposób możemy utworzyć wykres złożony z jedną liniową dla każdego rodzaju płatności (zakładka, wiza, gotówka)?Composite Graph z Crossfilter Przykład

+0

+1. Nie mam pojęcia, jak utworzyć go za pomocą złożonego wykresu. Myślę, że można to zrobić za pomocą wykresu serii. Jednak poczekam na poradę eksperta. –

+0

W tej chwili szukam przykładu złożonego koszyka, ponieważ to, czego naprawdę chcę, to wykreślić dwie serie i użyć .useRightYAxis (true), dzięki czemu mogę porównywać dwa zestawy danych z różnymi Y wartości osi. –

Odpowiedz

1

Zakładam, że chcesz wyświetlać płatność totals w czasie (wymiar date) dla każdej płatności type.

var payments = crossfilter([...]); 

var dateDimension = payments.dimension(function(d) { return new Date(d.date); }); 

Tworzenie grupy sumy płatności dla każdego rodzaju płatności (karta, wiza, pieniężnych)

var totalForType = function(type) { 
    return function(d) { 
    return d.type === type ? d.total : null; 
    }; 
}; 

var tabTotalsGroup = dateDimension.group().reduceSum(totalForType('tab')); 
var visaTotalsGroup = dateDimension.group().reduceSum(totalForType('visa')); 
var cashTotalsGroup = dateDimension.group().reduceSum(totalForType('cash')); 

zdefiniować kompozytowego wykres i korzystają z grup zdefiniować 3 wykresy liniowe jako część złożonego wykresu .

var compositeChart = dc.compositeChart('#composite-chart'); 
compositeChart 
    ... 
    .x(d3.time.scale().domain([new Date("2011-11-14T16:15:00Z"), new Date("2011-11-14T17:45:00Z")])) 
    .dimension(dateDimension) 
    .compose([ 
    dc.lineChart(compositeChart).group(tabTotalsGroup, 'tab').colors(['#ffaa00']), 
    dc.lineChart(compositeChart).group(visaTotalsGroup, 'visa').colors(['#aa00ff']), 
    dc.lineChart(compositeChart).group(cashTotalsGroup, 'cash').colors(['#00aaff']) 
    ]); 

dc.renderAll(); 

Pełny przykład: http://plnkr.co/edit/rhDURrDfeSvVqEnQR9L1?p=preview

+0

Doskonale, dziękuję. Zmieniłem go na wykres słupkowy, który ma nieco więcej sensu w tym kontekście. Mając to jako punkt wyjścia, byłem w stanie dostosować go do tego, co faktycznie próbowałem osiągnąć. –