메뉴 건너뛰기

조회 수 1093 댓글 0

<!DOCTYPE html>

<html>

 

<head>

    <title>

        폼으로 원형 그리기

    </title>

    <style>

        td {

            text-align: right;

            width: 80px;

            height: 30px;

        }

    </style>

 

</head>

 

<body>

    <h3>폼으로 원호 그리기</h3>

    <hr>

    <table>

        <tbody>

            <tr>

                <td>x</td>

                <td><input type="text" id="text1" value="100"></td>

                <td>y</td>

                <td><input type="text" id="text2" value="100"></td>

            </tr>

            <tr>

                <td>반지름</td>

                <td><input type="text" id="text3" value="80"></td>

                <td>방향</td>

                <td><select id="direc">

                        <!--시계방향=false // 반시계방향=true-->

                        <option value="false">시계방향</option>

                        <option value="true">반시계방향</option>

                    </select></td>

            </tr>

            <tr>

                <td>시작각도</td>

                <td><input type="text" id="text4" value="0"></td>

                <td>끝각도</td>

                <td><input type="text" id="text5" value="360"></td>

            </tr>

            <tr>

                <td>선굵기</td>

                <td><input type="text" id="text6" value="1"></td>

                <td>선색</td>

                <td><input type="color" id="color" ></td>

            </tr>

            <tr>

                <td></td>

                <td><input type="button" id="button1" value="그리기" onclick="draw()"></td>

                <td></td>

                <td><input type="button" id="button2" value="지우기" onclick="del()"></td>

            </tr>

        </tbody>

 

    </table>

    <canvas id="canvas" width="800" height="500" style="background:skyblue;"></canvas>

 

    <script>

        let canvas = document.getElementById("canvas");

        let context = canvas.getContext("2d");//잊어먹지말것

        let x, y, rad, direc, start_angle, end_angle, line_width, color, button1, button2;

 

        function draw() {

            context.beginPath(); 

            x = document.getElementById("text1");

            x = parseInt(x.value);

 

            y = document.getElementById("text2");

            y = parseInt(y.value);

 

            rad = document.getElementById("text3");

            rad = parseInt(rad.value);

 

            direc = document.getElementById("direc");// 다른거와다름

            direc = direc.value;

            

            

            start_angle = document.getElementById("text4");

            console.log("start 입력한 값 :"+start_angle.value);

            start_angle = (parseInt(start_angle.value))/180*Math.PI;//원주율 참고

           

            end_angle = document.getElementById("text5");

            console.log("end 입력한 값 :"+end_angle.value);

            end_angle = (parseInt(end_angle.value))/180*Math.PI;

          

            line_width = document.getElementById("text6");

            line_width = parseInt(line_width.value);

 

            color = document.getElementById("color");

            color=color.value;

 

            context.arc(x, y, rad, start_angle, end_angle, direc);//<< 문제발생!!!!!!!!!!!!!!!!!!!!

            console.log("시계반시계 :"+direc);

            console.log("start_angle :"+start_angle);

            console.log("end_angle :"+end_angle);

            context.strokeStyle=color;//이거 맞냐?

            console.log(color);

            context.lineWidth=line_width;

            

            context.stroke();

        }

 

        function del(){

            context.clearRect(0, 0, canvas.width, canvas.height);

        }

        


 

    </script>

</body>

 

</html>

 

----------------------------------

각도에 따라 호가 그려져야 되는데 각도와 반대된 상태로 뒤집어져서 그려지고 시계 반시계방향의 구분이 없어졌어요

?

QnA

공부하면서 궁금했던 것을 질문해보세요.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 읽어주세요! 연습문제 및 실습문제 정답 공개에 관한 공지입니다. file 관리자 2017.06.20 18281
323 385p 8장 실습문제 07번 질문입니다. 1 12345 2019.08.16 616
322 코드 잘못된 부분을 봐주시면 정말 감사하겠습니다 1 file 입문한 사람 2020.04.01 607
321 7장 실습문제 1번 질문 있습니다. 7 jonjsin 2017.11.09 603
320 timerID값이 null인 이유 1 열공이 2022.05.26 602
319 저자님 367페이지 질문있습니다~~ 1 file 칼잡이최제잘 2018.02.19 591
318 6장 7번 좀 알려주세요 ㅜㅜ 1 어려워여 2020.06.14 589
317 9장 onblur onfocus 활용 실습문제 2번 웹린이 2018.05.21 569
316 4장 6번문제 물어볼려고합니다 1 배재한 2019.04.16 566
315 5장 실습문제 9번 1 file 123 2018.10.03 563
314 교과서 13장 연습문제 1 알고싶어요 2021.05.29 553
313 9장 4번 질문있습니다. 웹프로그래밍 2017.05.28 551
312 이미지를 HTML 파일과 같은 폴더에 저장하였는데 왜 이미지가 보이지 않을까요? 1 황기태 2017.03.27 547
311 바닐라js 란 것에 대해 질문이 있습니다. 2 muuum 2018.11.01 546
310 1장 test1, 2, 3 파일 2 열공중 2020.03.07 542
309 간단한 질문 드립니다. 1 뚜룹 2018.06.07 535
308 이 책을 다 본 뒤 어떤 공부를 더 하는게 좋을까요? 1 file muuum 2018.10.31 526
307 8장 실습문제 8번 질문드립니다. 3 메론 2018.11.11 525
306 명품 HTML5+ 수정판 2장 4번 문제 문의 1 file mikael 2021.04.14 520
305 HTML5+CSS3+Javascript 웹 프로그래밍[수정판] 4 file Jenny 2021.09.25 519
304 오픈 챌린지 6장 1 ㄱㄷㄱㄷ 2018.04.22 514
목록
Board Pagination Prev 1 ... 2 3 4 5 6 7 8 9 10 ... 21 Next
/ 21
위로