Home Forums Chart Support Need help with Date time values in XAxis

Need help with Date time values in XAxis

Viewing 9 posts - 1 through 9 (of 9 total)
  • #23723

    I need to do 4 area charts with the same dataset (from database). In the table the date data is formatted like this = “2018-08-15 20:40:00” and for the Y data is a number value from another column. I figured out how to create the array with the data, and pass it trough json to the script, but I cant find the way to the chart get right the data.

    $sql = 'SELECT timestamp, valor
            FROM historial
            WHERE YEAR(timestamp) = YEAR(CURDATE())';
            // echo $sql."<br><br>";
    $resYear = mysqli_query($conn, $sql) or die(mysqli_error($conn));
    
    $arrYear = array();
    
    while($datos = mysqli_fetch_array($resYear, MYSQLI_NUM)){
        $arrYear[] =  array("x" => new DateTime($datos[0]), "y" => $datos[1]);
    }
    
    <script>
    			$(function () {
    		            var chart = new CanvasJS.Chart("year-chart", {
    					theme: "light2", // "light1", "light2", "dark1", "dark2"
    					animationEnabled: true,
    					zoomEnabled: true,
    					title: {
    						text: "Registros del año"
    					},
    					data: [{
    						type: "area",
                xValueType: "dateTime",
    						dataPoints: <?php echo json_encode($arrYear, JSON_NUMERIC_CHECK) ?>
    					}]
    				});
    				chart.render();
    			});
    
    		</script>

    With that solved I have to put that data in one chart visualized through time on year basis; month basis on another, week basis on the third and day basis (like between hours and minutes) on the last one. I dont figure how to do that either.

    #23726

    @hackkpo,

    You can read data from database, which gives you entire year data and render it in first chart. And for monthly and weekly data, you can filter data from the existing as shown in this Sample Project.
    Chart Data Grouping based on Year, Month & Week


    Vishwas R
    Team CanvasJS

    #23732

    But my problem is that isn’t rendered correctly, and i don’t know why, look (the pointed char is the result from that code)

    Page

    PD: I’ll look the shared sample, txs

    • This reply was modified 6 years ago by hackkpo.
    #23747

    @hackkpo,

    Can you kindly create JSFiddle with sample data reproducing the issue you are facing so that we can look into your code, understand the use-case better and help you out?


    Vishwas R
    Team CanvasJS

    #23768

    Yeah sure, here it is, I hope did it right

    JSFiddle

    #23769

    @hackkpo,

    The JSFiddle that you have shared seems to be working fine across browsers including Chrome, Firefox, Opera, Edge and IE. Here is the screenshot of the same.

    Can you kindly share the OS details and Browser details like browser name, version, etc so that we can try the same at our end.


    Vishwas R
    Team CanvasJS

    #23783

    You’re right! I didn’t notice haha. But how do i understand the chart? I mean, that query gives me 5000+ records, divided by 15 minutes in all the records from this year, but the x axis shows me this range

    chart

    And when you put the cursor on it, it says “18 Jan 70”, what it means?

    • This reply was modified 6 years ago by hackkpo.
    • This reply was modified 6 years ago by hackkpo.
    #23788

    @hackkpo,

    that query gives me 5000+ records, divided by 15 minutes in all the records from this year, but the x axis shows me this range

    Range of x-axis depends on the dataPoints, if minimum/maximum or viewportMinimum/viewportMaximum are not set. Kindly share JSFiddle with sample data so that we can look into the chart-options you are using, understand the scenario better and help you out.

    And when you put the cursor on it, it says “18 Jan 70”, what it means?

    Tooltip content is showing 1970 as the timestamp that you are passing to the dataPoints are PHP Timestamp. PHP uses Unix timestamp which is in seconds whereas JavaScript uses milliseconds as timestamp. Converting PHP timestamp to JS timestamp by multiplying PHP timestamp by 1000 should work fine in your case.


    Vishwas R
    Team CanvasJS

    #23847

    Finally got it working! The minimum and maximum attributes did all the magic, txs for the help Vishwas!

Viewing 9 posts - 1 through 9 (of 9 total)

You must be logged in to reply to this topic.