Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 01.01.2019, 18:14
Интересующийся
Отправить личное сообщение для grigandal Посмотреть профиль Найти все сообщения от grigandal
 
Регистрация: 18.02.2018
Сообщений: 26

Svg добавить path
На странице есть растянутое во всю ширину и высоту svg

<svg id="Arrows" width="100%" height="100%">
  <defs>
    <marker id="arrowhead" viewBox="0 0 10 10" refX="3" refY="5" markerWidth="6" markerHeight="6" orient="auto">
      <path d="M 0 0 L 10 5 L 0 10 z"></path>
    </marker>
  </defs>
</svg>


Хочу на нем нарисовать между элементами коннектор
Делаю это таким скриптом

var drawConnector = function(A, B) {
  var posnALeft = {
    x: A.offsetLeft - 8,
    y: A.offsetTop  + A.offsetHeight / 2
  };
  var posnARight = {
    x: A.offsetLeft + A.offsetWidth + 8,
    y: A.offsetTop  + A.offsetHeight / 2    
  };
  var posnBLeft = {
    x: B.offsetLeft - 8,
    y: B.offsetTop  + A.offsetHeight / 2
  };
  var posnBRight = {
    x: B.offsetLeft + B.offsetWidth + 8,
    y: B.offsetTop  + A.offsetHeight / 2
  };
  var dStr =
      "M" +
      (posnARight.x      ) + "," + (posnARight.y) + " " +
      "C" +
      (posnARight.x + 100) + "," + (posnARight.y) + " " +
      (posnBLeft.x - 100) + "," + (posnBLeft.y) + " " +
      (posnBLeft.x      ) + "," + (posnBLeft.y);
  var id = A.getAttribute('id') + "to" + B.getAttribute('id');
  if (!document.getElementById(id)){
    var path = document.createElement("path");
    path.setAttribute("id", id);
    path.setAttribute("fill","none");
    path.setAttribute("stroke","black");
    path.setAttribute("maker-end","url(#arrowhead)");
    path = document.getElementById("Arrows").appendChild(path);
  }
  document.getElementById(id).setAttribute("d", dStr);
   document.getElementById(id).innerHTML="ww";
};


Но добавленный path не отображается

Только когда в браузере удаляю его и вставляю через "Edit as HTML" он отображается, и то без стрелочки


Что я делаю не так и что надо делать, чтобы все отображалось?
Ответить с цитированием
  #2 (permalink)  
Старый 01.01.2019, 18:20
Интересующийся
Отправить личное сообщение для grigandal Посмотреть профиль Найти все сообщения от grigandal
 
Регистрация: 18.02.2018
Сообщений: 26

То есть, все отображается нормально, если меняю HTML вручную
А скриптом ничего не отображается, хотя в код добавляется
Ответить с цитированием
  #3 (permalink)  
Старый 01.01.2019, 18:28
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,109

Сообщение от grigandal
Что я делаю не так
createElementNS
setAttributeNS
Ответить с цитированием
  #4 (permalink)  
Старый 01.01.2019, 18:58
Интересующийся
Отправить личное сообщение для grigandal Посмотреть профиль Найти все сообщения от grigandal
 
Регистрация: 18.02.2018
Сообщений: 26

рони,
То есть, если я правильно понял, нужно так?

ar path = document.getElementById(id);
  if (!path){
	path = document.createElementNS("http://www.w3.org/2000/svg","path");
	path.setAttributeNS("http://www.w3.org/2000/svg","id", id);
	path.setAttributeNS("http://www.w3.org/2000/svg","fill","none");
	path.setAttributeNS("http://www.w3.org/2000/svg","stroke","black");
	path.setAttributeNS("http://www.w3.org/2000/svg","stroke-width","2");
	path.setAttributeNS("http://www.w3.org/2000/svg","maker-end","url(#arrowhead)");
	document.getElementById("Arrows").appendChild(path);
  }
  console.log(document.getElementById(id));
  path.setAttributeNS("http://www.w3.org/2000/svg","d", dStr);



Но все равно не отображается...

Последний раз редактировалось grigandal, 01.01.2019 в 19:10.
Ответить с цитированием
  #5 (permalink)  
Старый 01.01.2019, 19:12
Интересующийся
Отправить личное сообщение для grigandal Посмотреть профиль Найти все сообщения от grigandal
 
Регистрация: 18.02.2018
Сообщений: 26

рони,
Работает без setAttributeNS

Но стрелочка все равно не отображается, только линия
Ответить с цитированием
  #6 (permalink)  
Старый 01.01.2019, 19:14
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,109

grigandal,
посмотрите документацию и сделайте минимальный макет целиком, если останутся вопросы.
https://developer.mozilla.org/en-US/...reateElementNS
https://developer.mozilla.org/en-US/...setAttributeNS
http://javascript.ru/forum/showthrea...265#post110834
https://javascript.ru/forum/misc/667...tml#post439880

Последний раз редактировалось рони, 01.01.2019 в 19:55.
Ответить с цитированием
  #7 (permalink)  
Старый 01.01.2019, 19:57
Интересующийся
Отправить личное сообщение для grigandal Посмотреть профиль Найти все сообщения от grigandal
 
Регистрация: 18.02.2018
Сообщений: 26

рони,
Вот так вроде работает
var path = document.getElementById(id);
  if (!path){
	path = document.createElementNS("http://www.w3.org/2000/svg","path");
	document.getElementById("Arrows").appendChild(path);
	path.setAttribute("id", id);
	path.setAttribute("fill","none");
	path.setAttribute("stroke","black");
	path.setAttribute("stroke-width","2");
	path.setAttribute("maker-end","url(#arrowhead)");
	
  }
  path.setAttribute("d", dStr);


Но не рисуются наконечники стрелочек
Что не так?

Последний раз редактировалось grigandal, 01.01.2019 в 20:00.
Ответить с цитированием
  #8 (permalink)  
Старый 01.01.2019, 19:59
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,109

Сообщение от grigandal
Что не так?
Ответить с цитированием
  #9 (permalink)  
Старый 01.01.2019, 20:01
Интересующийся
Отправить личное сообщение для grigandal Посмотреть профиль Найти все сообщения от grigandal
 
Регистрация: 18.02.2018
Сообщений: 26

рони,
Только там path.setAttribute("maker-end","url(#arrowhead)");
а не path.setAttributeNS("maker-end","url(#arrowhead)");

Случайно вставил
Ответить с цитированием
  #10 (permalink)  
Старый 01.01.2019, 20:12
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,109

grigandal,
не знаю, что и как, вы хотите сделать.
могу только гадать, может нет элемента, может нет цвета или размера, может нарушен синтаксис.
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
SVG элементы path Sokoljr Общие вопросы Javascript 1 11.08.2017 18:54
Необходимо присвоить id всем элементам path в SVG AndreySt Общие вопросы Javascript 5 16.05.2016 17:33
Raphael.js карта - добавить polygon или path по клику на path рисунка карты Zaebalsya jQuery 0 04.01.2016 09:05
Добавить атрибут svg в масив Валерий1996 Общие вопросы Javascript 13 17.08.2015 15:58
SVG: background для Path debugx Общие вопросы Javascript 1 05.11.2011 07:28