СКРИПТЫ
ТЕГИ:
php (325)
js (242)
html (146)
css (130)
html tags (62)
js tag (56)
jquery (42)
text (37)
js method (36)
php array (33)
js date (33)
form html (30)
online (28)
fonts (26)
link (26)
Показать еще :
ruweb.net (25)
foto (22)
php file (20)
atom (20)
forum (19)
svg (18)
input (18)
hosting (18)
php date (17)
html book (16)
php time (16)
board (16)
color (15)
js url (14)
img (14)
js events (14)
js time (14)
info (13)
select (13)
osclass (13)
htaccess (13)
notepad (13)
знак (12)
php path (12)
keyboard (12)
php img (12)
download (12)
table (12)
dw block (12)
jsphp (11)
form (11)
icon (11)
yandex (10)
mouse (10)
js delete (10)
keyframes (10)
hover (9)
dosite (8)
browser (7)
cookie (7)
comment (7)
php url (7)
php get (6)
click (6)
mysql (6)
canvas (6)
list (6)
iframe (6)
js math (5)
reg.ru (5)
adminka (5)
mb (5)
heading (5)
tag a (5)
chart (5)
search (5)
ftp (5)
year (5)
js id (5)
value (5)
base64 (4)
day (4)
нок (4)
flags (4)
week (4)
xml (4)
scandir (4)
ssl (4)
bbcode (4)
php var (4)
games (4)
console (4)
js form (4)
vk (4)
pages (4)
submit (4)
month (4)
symbols (4)
task (4)
https (3)
js hash (3)
js post (3)
domen (3)
money (3)
vs code (3)
куб (3)
js img (3)
ucoz (3)
padding (3)
captcha (3)
numbers (3)
line (3)
tag hr (2)
qr kod (2)
youtube (2)
video (2)
рся (2)
sitemap (2)
counter (2)
details (2)
prompt (2)
typeof (2)
google (2)
height (2)
arrows (2)
seo (2)
js vars (2)
smile (1)
scroll (1)
speed (1)
нод (1)
archive (1)
header (1)
windows (1)
rutube (1)
jino (1)
cursor (1)

Как создать красивый график на сайте

17.02.2021 Марат 445 0 js | css | php | chart |
"Создание графиков", как сделать график на сайте, несколько видов графиков, столбчатый, график, диаграмма, волновой график с примерами. Будем использовать стороннюю библиотеку для визуализации графиков с примерами!

И последним разберем динамический график, который будет обновляться в зависимости от количества посещений страницы.

Подробно о графиках для сайта

  1. О библиотеке для графиков.
  2. Создание кругового графика(Pie Chart)
  3. Волновой график (Curving the Lines)
  4. Как сделать график динамическим(обновляемым)!?
  5. Как встроить график себе на сайт!?

  1. О библиотеке для графиков.

    Прежде чем приступать к графикам, нам нужна библиотека "Chart Gallery". Где её взять!? Или подключить!?

    Можно подключить, как внешний скрипт:

    <script type = "text/javascript" src = "https://www.gstatic.com/charts/loader.js">

    Вы можете поискать, где можно скачать данную библиотеку на сайте developers.google.com

    Либо можно скачать у нас

    Примеры построения графиков:

    Чтобы иметь представление, о чем вообще идет речь, о каких графиках, вот несколько готовых графиков на сегодня:

    Диаграмма - браузеры

    Столбчатый - браузеры по годам

    Волновой - браузеры по годам

    Линейный - посещаемость


  2. Создание кругового графика(Pie Chart)

    Давайте попробуем разобраться, как вообще сделать график на сайте? Начнем с того, как сделать круговой график (Pie Chart) пошагово, чтобы вы это смогли повторить!

    Открываем страницу developers.google.com - нас интересует "Pie Chart"

    Нажмите, чтобы открыть в новом окне.
    Создание кругового графика(Pie Chart)

    Далее ищем код, который стоит за картинкой... копируем и вставляем в любой редактор, либо даже блокнот и сохраняем, как html страницу.

    Нажмите, чтобы открыть в новом окне.
    Создание кругового графика(Pie Chart)

    Ну и далее заполняем все те данные, что имеются в массиве. Обращаю ваше внимание, что внутри массива - это штуки. Программа самы высчитает, сколько это будет составлять в процентах. И будет показывать и штуки и проценты.:

    ['Task', 'Hours per Day'],
    ['Work', 11],
    ['Eat', 2],
    ['Commute', 2],
    ['Watch TV', 2],
    ['Sleep', 7]

    Если мы говорим о примере, то мы изменили массив? таким образом:

    ['Task', 'Hours per Day'],
    ['Яндекс Браузер', 28.5],
    ['Google Chrome', 18.2],
    ['Opera', 13.9],
    ['Firefox', 11.1],
    ['MSIE', 5.05],
    ['Others', 23.25]

    Заменим :

    title: 'Общая статистика по браузерам в России за 2013 - 2020'

    Изменим "width" и "height"

    width: 100%; height: 100%;

    Конечный результат вывода графика на сайте

    Уже выше я показал круговой график


  3. Волновой график (Curving the Lines)

    Сначала - посмотрим, какой график будем строить... "волновой" с сглаженными углами.

    График: Curving the Lines - изогнутые линии:

    Открываем документацию

    Опять копируем код и помещаем его на страницу.

    Нажмите, чтобы открыть в новом окне.
    График: Curving the Lines - изогнутые линии:

    Что важно для нас и что мы поменяем!? Первая позиция - массив, поменяю на массив данных о браузерах.

    Вторая выделенная позиция на скрине - "bottom" -меняем на "right" - чтобы обозначения были справа от графика.

    И меняем высоту и ширину на:

    width: 100%; height: 100%;

    Результат получения волнового графика на сайте:

    Выше вы уже могли посмотреть на него - "волновой график для сайта"
    Еще вариант :

    Ну к примеру, как можно модифицировать данный график... ну например в переменной оставляем только один "title"

    var options = {title: 'здесь название'};
    То получим: угловатый график


  4. Как сделать график динамическим(обновляемым)!?

    Вообще - идея с графиком пошла с темы счетчика, когда я дошел до сохранения посещаемости по дням.

    Т.е. данный массив обновляется каждый день - что нам и нужно!

    Для того, чтобы сделать обновляемый каждый день график, нам понадобится(буду рассказывать на своем примере):

    Открываем документацию... поскольку ссылка срабатывает криво, заходим сюда и справа ищем кнопку - "Creating Material Line Charts"

    Нажмите, чтобы открыть в новом окне.
    Как сделать график динамическим(обновляемым)!?

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

    Array
    (
    [10.12.2020] => 7
    [all] => 10755
    [11.12.2020] => 22
    [12.12.2020] => 35
    [13.12.2020] => 24
    [14.12.2020] => 15
    [15.12.2020] => 18
    [16.12.2020] => 13
    [17.12.2020] => 17
    [18.12.2020] => 10
    [19.12.2020] => 8
    [20.12.2020] => 9
    [21.12.2020] => 11
    [22.12.2020] => 4
    [23.12.2020] => 5
    [24.12.2020] => 9
    [25.12.2020] => 10
    [26.12.2020] => 6
    [27.12.2020] => 3
    [28.12.2020] => 12
    [29.12.2020] => 8
    [30.12.2020] => 17
    [31.12.2020] => 9
    [01.01.2021] => 2
    [02.01.2021] => 3
    [03.01.2021] => 6
    [04.01.2021] => 6
    [05.01.2021] => 11
    [06.01.2021] => 9
    [07.01.2021] => 10
    [08.01.2021] => 7
    [09.01.2021] => 8
    [10.01.2021] => 4
    [11.01.2021] => 8
    [12.01.2021] => 5
    [13.01.2021] => 9
    [14.01.2021] => 15
    [15.01.2021] => 8
    [16.01.2021] => 10
    [17.01.2021] => 1
    [18.01.2021] => 12
    [19.01.2021] => 7
    [20.01.2021] => 15
    [21.01.2021] => 16
    [22.01.2021] => 10
    [23.01.2021] => 8
    [24.01.2021] => 27
    [25.01.2021] => 26
    [26.01.2021] => 16
    [27.01.2021] => 16
    [28.01.2021] => 12
    [29.01.2021] => 10
    [30.01.2021] => 12
    [31.01.2021] => 8
    [01.02.2021] => 12
    [02.02.2021] => 9
    [03.02.2021] => 13
    [04.02.2021] => 11
    [05.02.2021] => 10
    [06.02.2021] => 5
    [07.02.2021] => 4
    [08.02.2021] => 13
    [09.02.2021] => 13
    [10.02.2021] => 10
    [11.02.2021] => 8
    [12.02.2021] => 12
    [13.02.2021] => 14
    [14.02.2021] => 6
    [15.02.2021] => 13
    [16.02.2021] => 5
    [17.02.2021] => 21
    [18.02.2021] => 14
    [19.02.2021] => 8
    [20.02.2021] => 9
    [21.02.2021] => 13
    [22.02.2021] => 9
    [23.02.2021] => 14
    [24.02.2021] => 16
    [25.02.2021] => 17
    [26.02.2021] => 7
    [27.02.2021] => 11
    [02.03.2021] => 11
    [03.03.2021] => 19
    [04.03.2021] => 18
    [05.03.2021] => 8
    [06.03.2021] => 9
    [07.03.2021] => 9
    [08.03.2021] => 8
    [09.03.2021] => 9
    [10.03.2021] => 10
    [11.03.2021] => 8
    [12.03.2021] => 13
    [13.03.2021] => 11
    [14.03.2021] => 12
    [15.03.2021] => 13
    [16.03.2021] => 14
    [17.03.2021] => 10
    [18.03.2021] => 17
    [19.03.2021] => 10
    [20.03.2021] => 6
    [21.03.2021] => 7
    [22.03.2021] => 2
    [23.03.2021] => 6
    [24.03.2021] => 4
    [25.03.2021] => 10
    [26.03.2021] => 12
    [27.03.2021] => 15
    [28.03.2021] => 11
    [29.03.2021] => 28
    [30.03.2021] => 11
    [31.03.2021] => 16
    [01.04.2021] => 9
    [02.04.2021] => 25
    [03.04.2021] => 9
    [04.04.2021] => 10
    [05.04.2021] => 13
    [06.04.2021] => 15
    [07.04.2021] => 17
    [08.04.2021] => 22
    [09.04.2021] => 12
    [10.04.2021] => 6
    [11.04.2021] => 9
    [12.04.2021] => 5
    [13.04.2021] => 4
    [14.04.2021] => 14
    [15.04.2021] => 9
    [16.04.2021] => 12
    [17.04.2021] => 20
    [18.04.2021] => 28
    [19.04.2021] => 7
    [20.04.2021] => 13
    [21.04.2021] => 7
    [22.04.2021] => 15
    [23.04.2021] => 9
    [24.04.2021] => 12
    [25.04.2021] => 20
    [26.04.2021] => 21
    [27.04.2021] => 17
    [28.04.2021] => 11
    [29.04.2021] => 10
    [30.04.2021] => 23
    [01.05.2021] => 10
    [02.05.2021] => 14
    [03.05.2021] => 13
    [04.05.2021] => 13
    [05.05.2021] => 11
    [06.05.2021] => 14
    [07.05.2021] => 13
    [08.05.2021] => 16
    [09.05.2021] => 10
    [10.05.2021] => 21
    [11.05.2021] => 20
    [12.05.2021] => 13
    [13.05.2021] => 27
    [14.05.2021] => 107
    [15.05.2021] => 64
    [16.05.2021] => 34
    [17.05.2021] => 34
    [18.05.2021] => 33
    [19.05.2021] => 35
    [20.05.2021] => 41
    [21.05.2021] => 41
    [22.05.2021] => 19
    [23.05.2021] => 27
    [24.05.2021] => 24
    [25.05.2021] => 23
    [26.05.2021] => 20
    [27.05.2021] => 23
    [28.05.2021] => 25
    [29.05.2021] => 24
    [30.05.2021] => 11
    [31.05.2021] => 25
    [01.06.2021] => 23
    [02.06.2021] => 29
    [03.06.2021] => 26
    [04.06.2021] => 40
    [05.06.2021] => 34
    [06.06.2021] => 34
    [07.06.2021] => 32
    [08.06.2021] => 39
    [09.06.2021] => 33
    [10.06.2021] => 41
    [11.06.2021] => 62
    [12.06.2021] => 36
    [13.06.2021] => 44
    [14.06.2021] => 67
    [15.06.2021] => 71
    [16.06.2021] => 61
    [17.06.2021] => 63
    [18.06.2021] => 58
    [19.06.2021] => 66
    [20.06.2021] => 62
    [21.06.2021] => 40
    [22.06.2021] => 16
    [23.06.2021] => 19
    [24.06.2021] => 27
    [25.06.2021] => 4
    [26.06.2021] => 11
    [27.06.2021] => 24
    [28.06.2021] => 15
    [29.06.2021] => 29
    [30.06.2021] => 41
    [01.07.2021] => 24
    [02.07.2021] => 19
    [03.07.2021] => 22
    [04.07.2021] => 17
    [05.07.2021] => 19
    [06.07.2021] => 21
    [07.07.2021] => 60
    [08.07.2021] => 58
    [09.07.2021] => 49
    [10.07.2021] => 38
    [11.07.2021] => 45
    [12.07.2021] => 55
    [13.07.2021] => 33
    [14.07.2021] => 40
    [15.07.2021] => 47
    [16.07.2021] => 52
    [17.07.2021] => 43
    [18.07.2021] => 55
    [19.07.2021] => 56
    [20.07.2021] => 59
    [21.07.2021] => 64
    [22.07.2021] => 55
    [23.07.2021] => 28
    [24.07.2021] => 70
    [25.07.2021] => 75
    [26.07.2021] => 53
    [27.07.2021] => 36
    [28.07.2021] => 15
    [29.07.2021] => 27
    [30.07.2021] => 17
    [31.07.2021] => 9
    [01.08.2021] => 27
    [02.08.2021] => 22
    [03.08.2021] => 31
    [04.08.2021] => 18
    [05.08.2021] => 19
    [06.08.2021] => 30
    [07.08.2021] => 48
    [08.08.2021] => 92
    [09.08.2021] => 16
    [10.08.2021] => 31
    [11.08.2021] => 77
    [12.08.2021] => 32
    )

    У меня есть массив! Теперь выведем его внутри javascript - позиция на скрине №2. С помощью цикла foreach - выводим все данный в массив, кроме ячейки, где лежит общее количество(all). См выше кнопка показать массив.

    Код, который будет создавать массив javascript .

    <?
    foreach ($ARRAY_COUNT_VISITS as $key => $value)
    {
      if( $key!="all"){
         echo '[\''.$key.'\','.$value .'],';
       }
    }
    ?>

    Давайте посмотрим на этот массив уже на странице - нажимаем ctrl + U(обращаю ваше внимание, на последнюю ячейку - это дата, когда вы смотрите эту страницу дата будет другая)

    Нажмите, чтобы открыть в новом окне.
    Как сделать график динамическим(обновляемым)!?

    Далее выводим всего сколько:

    Всего посетило страницу : <?=$ARRAY_COUNT_VISITS['all']?>

    И последнее добавим "curveType: 'function'" - вывод в виде функции.

    Скриншот, на который я ранее несколько раз ссылался:

    Нажмите, чтобы открыть в новом окне.
    Как сделать график динамическим(обновляемым)!?

    Результат вывода волнового графика(обновляемого)

    График линейный-волновой
    Скачать.

    Если вы встречаетесь с построением графика впервые, то все это понять с первого раза невозможно! Даже мне пришлось немного попотеть!

    Поэтому, чтобы вы могли посмотреть на данный код, я сделаю архив, который вы сможете скачать


  5. Как встроить график себе на сайт!?


    График столбчатый() встроить:

    Полноэкранная версия.
    Код для вставки на страницу:

    <iframe style ="width:750px;height:550px;border:none;margin:20px 0;" src="https://dwweb.ru/charts/browser_statistics_in_russia_percent.html"></iframe>

    Результат :


    График() встроить:

    Разбираюсь, почему не растягивается на всю ширину блока... надеюсь скоро решу...
    Полноэкранная версия.
    Код для вставки на страницу:

    <iframe style ="width:750px;height:550px;border:none;margin:20px 0;" src="https://dwweb.ru/__img/__charts/gravik_lineynyiy_javascript.html"></iframe>

    Результат :



    График() встроить:

    Полноэкранная версия.
    Код для вставки на страницу:

    <iframe style ="width:750px;height:550px;border:none;margin:20px 0;" src="https://dwweb.ru/__img/__charts/diagramma_statistiki_po_brauzeram.html"></iframe>

    Результат :



    График() встроить:

    Полноэкранная версия.
    Код для вставки на страницу:

    <iframe style ="width:750px;height:550px;border:none;margin:20px 0;" src="https://dwweb.ru/charts/stat_all_os_short.html"></iframe>

    Результат :


Не благодарите, но ссылкой можете поделиться!
Временная ссылка для быстрейшей индексации : список всех квадратных корней.
Теги :
Создание графиков
графики на сайте
Еще никто не прокомментировал! COMMENTS+   BBcode
Подписаться + =

ruweb dwweb.ru есть здесь:
Последние комментарии :
Марат :
15.08.2023 17:50
Значит в "maxv" сидит…
подробнее.
михаил :
15.08.2023 16:53
а если это сделано для диаграммы values / maxv)…
подробнее.
Марат :
17.07.2023 15:50
Спасибо за интересный вопрос! Посмотрите …
подробнее.
Александр :
17.07.2023 14:58
а как сделать чтобы при повторном клике значение value возвращалось к…
подробнее.
Марат :
30.06.2023 10:18
Спасибо за внимательность!
подробнее.
???? :
29.06.2023 15:37
Прямоугольник - это геометрическая фигура, у которой три угла…
подробнее.
Немного о ruweb.net!
Страница загружена за : 0.02591 секунд. Подробнее