ฉันต้องการแสดงภาพการประทับเวลาของเหตุการณ์ในข้อมูลของฉันโดยใช้การแสดงภาพดังที่แสดงด้านล่าง:
ฉันเดาว่าสามารถทำได้หลายวิธี และเนื่องจากฉันไม่มีประสบการณ์กับ D3 ฉันจึงอยากได้ยินคำแนะนำสำหรับแนวทางที่ดี บางทีมันอาจจะสำเร็จได้ด้วยการปรับแต่งการแสดงภาพข้อมูลทั่วไปด้วยวิธีที่ซับซ้อนใช่ไหม?
แก้ไข: ตามคำติชมจาก ee2Dev ฉันจะทำ 4 บรรทัดแทนที่จะเป็น 2 บรรทัด โดยแยกการโทร/ข้อความเข้าและออกแยกกัน ในส่วนของรายละเอียด จะเป็นการดีที่สุดหากการแสดงภาพสามารถบันทึกข้อมูลหนึ่งสัปดาห์ในช่วงเวลา 5 นาที (หนึ่งข้อความจะเท่ากับการสนทนา 5 นาที และการโทร 48 นาทีจะถูกปัดเศษเป็นการโทร 50 นาที) นั่นจะเท่ากับ 7*24*12 = 2016 ช่วงเวลาที่เป็นไปได้ ซึ่งดูเหมือนค่อนข้างสมเหตุสมผล บางทีช่วงเวลา 10 นาทีอาจจะเหมาะสมกว่าช่วงเวลา 5 นาที แต่ฉันเดาว่าโค้ดสามารถปรับได้อย่างง่ายดาย สิ่งที่ฉันไม่ได้แสดงคือควรทำเครื่องหมายเที่ยงคืนอย่างไรเพื่อแสดงว่าวันไหนใช้งานและวันใดที่ไม่ใช้งาน
ด้านล่างนี้คือโค้ดและข้อมูลตัวอย่างของฉัน:
// Data:
timestamp (yyyy-MM-dd HH:mm),type
1/1/2015 10:12,inc_call
1/2/2015 10:12,inc_call
1/2/2015 10:12,out_text
1/3/2015 10:12,out_call
1/4/2015 10:12,inc_text
1/5/2015 10:12,inc_text
// Code
<!DOCTYPE html>
<meta charset="utf-8">
<style>
</style>
<body>
<script type="text/javascript" src="d3/d3.js"></script>
<script type="text/javascript" src="papaparse.js"></script>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="jquery.tipsy.js"></script>
<link href="/thtipsy.css" rel="stylesheet" type="text/css" />
<script>
var width = 1000;
var height = 500;
var events;
var results = Papa.parse("events.csv", {
header: true,
download: true, // is needed even for local files as this interprets the input value as a path instead of simply the data
dynamicTyping: true,
delimiter: ",",
skipEmptyLines: true,
complete: function(results) {
events = results.data;
CreateVisualizationFromData();
}
});
var svg = d3.select("body").append("svg")
.attr("width", width)
.attr("height", height);
var total_interactions;
function CreateVisualizationFromData()
{
total_interactions = events.length;
console.log(total_interactions);
svg
.append("marker")
.attr("id", "arrowhead")
.attr("refX", 6 + 7)
.attr("refY", 2)
.attr("markerWidth", 6)
.attr("markerHeight", 4)
.attr("orient", "auto")
.append("path")
.attr("d", "M 0,0 V 4 L6,2 Z");
}