모바일 오유 바로가기
http://m.todayhumor.co.kr
분류 게시판
베스트
  • 베스트오브베스트
  • 베스트
  • 오늘의베스트
  • 유머
  • 유머자료
  • 유머글
  • 이야기
  • 자유
  • 고민
  • 연애
  • 결혼생활
  • 좋은글
  • 자랑
  • 공포
  • 멘붕
  • 사이다
  • 군대
  • 밀리터리
  • 미스터리
  • 술한잔
  • 오늘있잖아요
  • 투표인증
  • 새해
  • 이슈
  • 시사
  • 시사아카이브
  • 사회면
  • 사건사고
  • 생활
  • 패션
  • 패션착샷
  • 아동패션착샷
  • 뷰티
  • 인테리어
  • DIY
  • 요리
  • 커피&차
  • 육아
  • 법률
  • 동물
  • 지식
  • 취업정보
  • 식물
  • 다이어트
  • 의료
  • 영어
  • 맛집
  • 추천사이트
  • 해외직구
  • 취미
  • 사진
  • 사진강좌
  • 카메라
  • 만화
  • 애니메이션
  • 포니
  • 자전거
  • 자동차
  • 여행
  • 바이크
  • 민물낚시
  • 바다낚시
  • 장난감
  • 그림판
  • 학술
  • 경제
  • 역사
  • 예술
  • 과학
  • 철학
  • 심리학
  • 방송연예
  • 연예
  • 음악
  • 음악찾기
  • 악기
  • 음향기기
  • 영화
  • 다큐멘터리
  • 국내드라마
  • 해외드라마
  • 예능
  • 팟케스트
  • 방송프로그램
  • 무한도전
  • 더지니어스
  • 개그콘서트
  • 런닝맨
  • 나가수
  • 디지털
  • 컴퓨터
  • 프로그래머
  • IT
  • 안티바이러스
  • 애플
  • 안드로이드
  • 스마트폰
  • 윈도우폰
  • 심비안
  • 스포츠
  • 스포츠
  • 축구
  • 야구
  • 농구
  • 바둑
  • 야구팀
  • 삼성
  • 두산
  • NC
  • 넥센
  • 한화
  • SK
  • 기아
  • 롯데
  • LG
  • KT
  • 메이저리그
  • 일본프로야구리그
  • 게임1
  • 플래시게임
  • 게임토론방
  • 엑스박스
  • 플레이스테이션
  • 닌텐도
  • 모바일게임
  • 게임2
  • 던전앤파이터
  • 마비노기
  • 마비노기영웅전
  • 하스스톤
  • 히어로즈오브더스톰
  • gta5
  • 디아블로
  • 디아블로2
  • 피파온라인2
  • 피파온라인3
  • 워크래프트
  • 월드오브워크래프트
  • 밀리언아서
  • 월드오브탱크
  • 블레이드앤소울
  • 검은사막
  • 스타크래프트
  • 스타크래프트2
  • 베틀필드3
  • 마인크래프트
  • 데이즈
  • 문명
  • 서든어택
  • 테라
  • 아이온
  • 심시티5
  • 프리스타일풋볼
  • 스페셜포스
  • 사이퍼즈
  • 도타2
  • 메이플스토리1
  • 메이플스토리2
  • 오버워치
  • 오버워치그룹모집
  • 포켓몬고
  • 파이널판타지14
  • 배틀그라운드
  • 기타
  • 종교
  • 단어장
  • 자료창고
  • 운영
  • 공지사항
  • 오유운영
  • 게시판신청
  • 보류
  • 임시게시판
  • 메르스
  • 세월호
  • 원전사고
  • 2016리오올림픽
  • 2018평창올림픽
  • 코로나19
  • 2020도쿄올림픽
  • 게시판찾기
  • 오유인페이지
    개인차단 상태
    지빵님의
    개인페이지입니다
    가입 : 10-12-21
    방문 : 2004회
    닉네임변경 이력
    회원차단
    회원차단해제
    게시물ID : programmer_18312
    작성자 : 빵미인아
    추천 : 0
    조회수 : 1434
    IP : 222.113.***.220
    댓글 : 3개
    등록시간 : 2016/08/30 22:20:21
    http://todayhumor.com/?programmer_18312 모바일
    d3.js 질문입니다.
    옵션
    • 본인삭제금지
    캡처.PNG

    노드와 링크를 구성하여 그래프(차트말고 트리같이 노드와 링크로 구성하는 그래프)를 생성하는건데 인터넷에 공개된 예제를 가져와서 수정한것입니다.
    그런데 노드들이 저렇게 다닥다닥 붙어서 생성이 되네요..
    노드 안의 글자는 위치조정만 하면 되니까 무시하셔두 되구요

    노드들만 다닥다닥 안 붙게하고싶은데
    이게 어느 부분에서인가 노드들의 위치 좌표를 설정해서 그 좌표대로 생성되는거 같은데
    어디서 설정이 되는지 모르겟습니다..

    아래 코드를 통해 제가 의문이 가는 부분에 질문을 적겠습니다.

    1. Text.json

    {
      "nodes": [
        {"id": "Myriel", "group": 1},
        {"id": "Napoleon", "group": 2},
        {"id": "Mlle.Baptistine", "group": 3},
        {"id": "A", "group": 4}

      ],
      "links": [
        {"source": "Napoleon", "target": "Myriel", "value": 100},
        {"source": "Mlle.Baptistine", "target": "Myriel", "value": 200},
        {"source": "Mlle.Baptistine", "target": "A", "value": 300}

      ]
    }



    2. Example.html

    <!DOCTYPE html>
    <meta charset="utf-8">
    <style>

    .links line {
      stroke: #999;
      stroke-opacity: 0.6;
    }

    .nodes circle {
      stroke: #fff;
      stroke-width: 1.5px;
    }

    </style>
    <svg width="1350" height="900"></svg>
    <script src="https://d3js.org/d3.v4.min.js"></script>
    <script>
    var svg = d3.select("svg"),
        width = +svg.attr("width"),
        height = +svg.attr("height");

    var color = d3.scaleOrdinal(d3.schemeCategory20);

    var simulation = d3.forceSimulation()
        .force("link", d3.forceLink().id(function(d) {console.log(d); return d.id; }))
        .force("charge", d3.forceManyBody())
        .force("center", d3.forceCenter(width / 2, height / 2));
    ↑ 의문1 : 이 부분이 정확히 무슨 역할인지 모르겠습니다. 구글링을 통해 대충 그래프를 만들때 사용하는거로 보이긴 하는데 자세히 모르겠네요 어쩌면 이 부분의 역할을 몰라서 못하고 있는걸지도 모르겠네요...



    //d3.json("TestAll.json", function(error, graph) {
    d3.json("Test.json", function(error, graph) {
      if (error) throw error;

      var link = svg.append("g")
          .attr("class", "links")
        .selectAll("line")
        .data(graph.links)
        .enter().append("line")
          .attr("stroke-width", function(d) { return Math.sqrt(30); });

      var node = svg.append("g")
          .attr("class", "nodes")
        .selectAll("circle")
        .data(graph.nodes)
        .enter().append("circle")
          .attr("r", 50)
          .attr("fill", function(d) { return color(d.group); })
          .call(d3.drag()
              .on("start", dragstarted)
              .on("drag", dragged)
              .on("end", dragended));

      var city = svg.append("g")
          .selectAll("text")
          .data(graph.nodes)
          .enter()
          .append("text")
          .text(function(d){ return d.id })
    ↑ 의문2 : 이 부분에서 링크와 노드와 노드 안 내용을 생성하는건 알겠습니다. 혹시 여기서 자동으로 각 노드들의 좌표가 생성이 자동으로 되는 것인가요?



      node.append("title")
          .text(function(d) { return d.id; });

      simulation
          .nodes(graph.nodes)
          .on("tick", ticked);

      simulation.force("link")
          .links(graph.links);


      function ticked() {
        link
            .attr("x1", function(d) { return d.source.x; })
            .attr("y1", function(d) { return d.source.y; })
            .attr("x2", function(d) { return d.target.x; })
            .attr("y2", function(d) { return d.target.y; });

        node
            .attr("cx", function(d) { return d.x; })
            .attr("cy", function(d) { return d.y; });

        city
            .attr("x", function(d) { return d.x; })
            .attr("y", function(d) { return d.y; });
      }
    });
    ↑ 의문3 : 직접적으로는 이 부분에서 좌표를 적어주어 화면에 나타내주는 것이지만 위 함수들에서 리턴해주는 것을 보면 d.source.x입니다. 이미 해당 데이터가 x좌표와 y좌표를 가지고 있어서 이 함수는 해당 데이터에서 맞는 좌표들을 불러와서 html에 지정만 해주는거네요.. 이 좌표들은 대체 언제 지정이된거죠? 데이터인 json파일엔 적혀있지도 않은데요..



    function dragstarted(d) {
      if (!d3.event.active) simulation.alphaTarget(0.3).restart();
      d.fx = d.x;
      d.fy = d.y;
    }

    function dragged(d) {
      d.fx = d3.event.x;
      d.fy = d3.event.y;
    }

    function dragended(d) {
      if (!d3.event.active) simulation.alphaTarget(0);
      d.fx = null;
      d.fy = null;
    }

    </script>


    이 게시물을 추천한 분들의 목록입니다.
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)

    죄송합니다. 댓글 작성은 회원만 가능합니다.

    번호 제 목 이름 날짜 조회 추천
    414
    mongodb 써보려고 하는데 접근 허용이 안된다네여?? [1] 본인삭제금지 빵미인아 16/10/09 20:32 26 0
    413
    데이터베이스 연동 질문합니다!! [1] 본인삭제금지 빵미인아 16/10/09 18:09 34 0
    412
    디바 아이헨발데 잘하진 않아도 음성녹음 해봤어용 ㅋㅋ [1] 창작글 빵미인아 16/10/05 02:59 68 0
    411
    송하나 괴롭히는 나쁜놈들 처리하는 토르비욘의 망치 빵미인아 16/10/03 02:52 133 0
    410
    오버워치 하면서 쓸 마이크 추천이여!! 본인삭제금지 빵미인아 16/10/01 23:22 29 0
    409
    전리품상자 11개+1개 제가 한번 까보겠습니다 [4] 창작글 빵미인아 16/09/30 00:58 144 5
    408
    혹시 WebVOWL아시나요? 본인삭제금지 빵미인아 16/09/23 16:05 43 0
    407
    한조를 하다 [2] 빵미인아 16/09/21 13:27 229 1
    406
    가수 김조한 있자나요!! [1] 빵미인아 16/09/20 22:25 155 0
    405
    d3.js에서 node좌표값이 NaN이 됩니다 [1] 본인삭제금지 빵미인아 16/09/19 14:40 50 0
    404
    서버는 블코랑 관계가 없다고합니다 [7] 빵미인아 16/09/18 14:01 410 2
    403
    심심이 메이코패스설 빵미인아 16/09/16 12:36 256 1
    402
    node.js 서버에서 클라이언트로 특정 함수를 실행시키게 할 수 있나요 [2] 본인삭제금지 빵미인아 16/09/07 00:25 24 0
    401
    node.js 파일 업로드후 그 파일 불러올때.. [1] 본인삭제금지 빵미인아 16/09/07 00:01 20 0
    400
    구글 차트 API인데요 질문좀요 [2] 본인삭제금지 빵미인아 16/09/06 17:18 55 0
    399
    배치 미국섭에서 하면 뭐가 다른가요? [3] 빵미인아 16/09/04 17:01 129 0
    398
    d3.js 아래 질문 이어서 올립니다. [5] 본인삭제금지 빵미인아 16/08/31 16:08 31 0
    d3.js 질문입니다. [3] 본인삭제금지 빵미인아 16/08/30 22:20 35 0
    396
    인생 디바궁!! [4] 빵미인아 16/08/25 06:31 183 5
    395
    오늘자 암살자 디바 빵미인아 16/08/22 21:51 84 1
    394
    자바스크립트 동적으로 추가한 html태그 새로고침해도 유지하는법 질문이요 [5] 본인삭제금지 빵미인아 16/08/22 01:30 46 0
    393
    node.js 서버에 JSON파일을 올리고 그 파일을 가져와서 사용 [4] 본인삭제금지 빵미인아 16/08/21 21:16 38 0
    392
    안드로이드 어그로 광고 차단방법 [1] 본인삭제금지 빵미인아 16/08/20 23:07 34 0
    391
    원펀골 [3] 빵미인아 16/08/20 20:40 91 0
    390
    바스티온 애니메이션 나온 후 미국섭 [3] 빵미인아 16/08/19 18:04 328 5
    389
    미국섭에서 수치플레이 [1] 빵미인아 16/08/18 22:49 144 4
    388
    node.js 관련 질문입니다. [4] 본인삭제금지 빵미인아 16/08/18 18:30 39 0
    387
    크로스 도메인? 질문합니다. [4] 본인삭제금지 빵미인아 16/08/18 16:27 40 0
    386
    node.js질문입니다 [3] 본인삭제금지 빵미인아 16/08/18 16:23 32 0
    385
    일리오스 우물 디바궁 버그있네요 [1] 빵미인아 16/08/18 12:12 254 0
    [◀이전10개] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [다음10개▶]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈