Return to Video

Lecture 21 | Programming Methodology (Stanford)

  • 0:08 - 0:11
    ...
  • 0:11 - 0:14
    이 강의는 스탠포드에서 전문인 양성을 위하여
  • 0:14 - 0:21
    제공됩니다.
  • 0:22 - 0:27
    지난 시간의 주제를 이어서 공부해 봅시다
  • 0:27 - 0:31
    우리의 친구, 상호작용자를 배우고 있었죠
  • 0:31 - 0:34
    상호작용자와 액션 리스너에 대해서요
  • 0:34 - 0:39
    구체적으로는 버튼을 만드는 방법과 그 버튼들에 의해 발생하는 액션 이벤트에 대해 배웠습니다
  • 0:39 - 0:42
    기억하나요? 그걸 간단히 정리하고 좀 더 깊이 있는 내용을 배워봅시다
  • 0:42 - 0:47
    지난 시간에 이야기 했던 것 중 하나가 바로 프로그램에 init 메소드를 만드는 것이었습니다
  • 0:47 - 0:50
    public void고요
  • 0:50 - 0:54
    이 메소드 안에서 프로그램의 일부를
  • 0:54 - 0:57
    다양한 사용자들을 클릭하거나 해서
  • 0:57 - 1:00
    어떠한 이벤트가 발생했을 때의 상황을 처리해 줄 수 있었죠
  • 1:00 - 1:03
    액션 리스너를 add해 줌으로써요
  • 1:03 - 1:08
    그래서 버튼을 클릭하면
  • 1:08 - 1:10
    특정한 메소드를 호출하도록 처리해 주는 것입니다
  • 1:10 - 1:14
    액션리스너는 예를 들어 프로그램의 버튼이 있을 때 버튼에 무슨 일이 일어나는 지 감시해주었습니다
  • 1:14 - 1:18
    그래서 버튼을 클릭하면 특정한 메소드를 호출하도록 처리해 주는 것입니다
  • 1:18 - 1:21
    예를 들어 actionPerformed를 호출하면 그것에 바탕하여 어떤 버튼이 눌렸는 지를 확인하고
  • 1:21 - 1:24
    실제로 무엇인가를 실행해줍니다 아셨죠?
  • 1:24 - 1:28
    자 여기 우리의 친구 public void actionPerformed가 있습니다
  • 1:28 - 1:31
    자 여기 우리의 친구 public void actionPerformed가 있습니다
  • 1:31 - 1:33
    자 여기 우리의 친구 public void actionPerformed가 있습니다
  • 1:33 - 1:34
    자 여기 우리의 친구 public void actionPerformed가 있습니다
  • 1:34 - 1:38
    그리고 actionPerformed는 ActionEvent라고 부르는 인자를 갖습니다.
  • 1:38 - 1:40
    그리고 actionPerformed는 ActionEvent라고 부르는 인자를 갖습니다.
  • 1:40 - 1:44
    액션 이벤트를 우리는 여기서 e라고 지칭해주고요
  • 1:44 - 1:48
    이것은 어떤 액션이 일어났는지 혹은 어떤 버튼이 클릭되었는지를 확인해 줍니다
  • 1:48 - 1:51
    기억하고 있길 바래요
    지난 시간 수업을 잠시 돌아봤고요
  • 1:51 - 1:54
    이제 액션 이벤트가 생겼을 때, 몇 가지 할 일이 있다고 했었죠
  • 1:55 - 1:58
    가장 중요한 것은
  • 1:58 - 2:02
    어떤 코맨드가 이 액션 이벤트를 발생시켰는 지를 알아내는 겁니다
  • 2:02 - 2:03
    어떤 코맨드가 이 액션 이벤트를 발생시켰는 지를 알아내는 겁니다
  • 2:03 - 2:06
    이렇게 하는 거죠
  • 2:06 - 2:09
    일단 문자열 cmd를 만듭니다 command의 줄임말이고요
  • 2:09 - 2:12
    이 코맨드, 즉 상호작용자는 actionPerfromed 메소드를 호출합니다
  • 2:12 - 2:16
    이 코맨드, 즉 상호작용자는 actionPerfromed 메소드를 호출합니다
  • 2:17 - 2:19
    자 여기서 e.cmd = e.getActionCommand를 써주세요
  • 2:19 - 2:22
    자 여기서 e.cmd = e.getActionCommand를 써주세요
  • 2:22 - 2:26
    . getActionCommand가 하는 일은 바로
  • 2:26 - 2:30
    상호작용자의 이름을 문자열로 리턴시켜 주는 것입니다
  • 2:30 - 2:33
    그리고 버튼의 이름은 기본적으로 버튼에 써져있는 것입니다
  • 2:33 - 2:34
    그리고 버튼의 이름은 기본적으로 버튼에 써져있는 것입니다
  • 2:34 - 2:38
    그리고 몇 개의 if를 이 cmd를 바탕으로 여기 써줍니다
  • 2:38 - 2:41
    if(cmd.equal)으로 확인해서 어떤 버튼이 눌려졌는 지에 따라 액션을 취해 줄 수 있도록
  • 2:41 - 2:43
    버튼의 이름을 확인 할 수 있습니다
  • 2:43 - 2:46
    사실 이 액션 코맨드cmd보다는
  • 2:46 - 2:48
    ActionEvent e를 활용해서 할 수 있는 것이 더 많습니다
  • 2:48 - 2:51
    이걸 지난 수업 때 간단히 봤었는데요
    우리가 했던 프로그램에서요
  • 2:51 - 2:54
    이제 이걸 좀 더 배워봅시다 좀 더 시간을 들여서요
  • 2:54 - 2:57
    이제 저희가 원하는 것은 e에서 액션 코맨드를 알아내는 것이 아닙니다
  • 2:57 - 3:01
    액션의 소스를 직접 가져오는 것을 바라죠
  • 3:01 - 3:03
    액션의 소스를 직접 가져오는 것을 바라죠
  • 3:03 - 3:07
    자, 여기서 재밌는 것은 getSource가 리턴하는 내용입니다
  • 3:07 - 3:09
    여기선 잠시 세미콜론을 뺄게요
  • 3:09 - 3:13
    getSource는 오브젝트(객체)를 리턴해 줍니다
  • 3:13 - 3:18
    이벤트를 발생시키는 오브젝트 자체를 리턴해주죠
  • 3:18 - 3:20
    즉, 버튼을 클릭했다면
  • 3:20 - 3:23
    e.getActionCommand는 버튼의 이름을 리턴해주고
  • 3:23 - 3:28
    e.getSource는 버튼 오브젝트의 레퍼런스를 리턴해 줍니다
  • 3:28 - 3:31
    즉 오브젝트를 참조할 수 있게 되는 겁니다
  • 3:31 - 3:32
    즉 오브젝트를 참조할 수 있게 되는 겁니다
  • 3:32 - 3:35
    이것은 어떤 의미를 가질까요
  • 3:35 - 3:38
    여기서 이것은 여러분이 초기화를 설정 할 때
  • 3:38 - 3:41
    여기서 이것은 여러분이 초기화를 설정 할 때
  • 3:41 - 3:43
    new JButton을 해줍니다
  • 3:43 - 3:45
    new JButton을 해줍니다
  • 3:45 - 3:46
    new JButton을 해줍니다
  • 3:46 - 3:51
    이걸 hi라고 할게요. 알겠죠
  • 3:51 - 3:55
    그리고 hi = new JButton을 해주고요
  • 3:55 - 3:58
    hi를 인스턴스 변수로 만든거죠
  • 3:58 - 4:02
    그럼 프로그램 내에 인스턴스 변수, private JButton hi가 생겼습니다.
  • 4:02 - 4:03
    그럼 프로그램 내에 인스턴스 변수, private JButton hi가 생겼습니다.
  • 4:03 - 4:10
    hi라는 변수를 선언했고요, JButton입니다
  • 4:10 - 4:14
    그리고 초기화 메소드에서
  • 4:14 - 4:18
    이 버튼에 라벨 hi를 붙여 생성합니다
  • 4:18 - 4:21
    그런 다음 이것을 컨트롤 바에 add해 줍니다
  • 4:21 - 4:25
    예를 들어 이 hi를 SOUTH 컨트롤 바에 add시켜 주죠
  • 4:25 - 4:29
    여기에 add하는 게 일반적이라서요
  • 4:29 - 4:30
    버튼이 실제로 화면 상에 나타나는 걸 보는 건 즐겁죠
  • 4:30 - 4:32
    버튼이 실제로 화면 상에 나타나는 걸 보는 건 즐겁죠
  • 4:32 - 4:35
    이렇게 add시켜 준 뒤에 이벤트 발생을 기다리는 거죠
  • 4:35 - 4:36
    이렇게 add시켜 준 뒤에 이벤트 발생을 기다리는 거죠
  • 4:36 - 4:38
    그리고 이 버튼이 클릭 될 때를 위한 액션 리스너를 add해 줍니다
  • 4:38 - 4:40
    이제 버튼이 클릭 되면
  • 4:40 - 4:41
    이 버튼의 cmd로
  • 4:41 - 4:42
    이 버튼의 이름을 가져오라고 요청할 수 있어요
  • 4:42 - 4:47
    혹은 액션 이벤트에게 액션 코맨드의 이름을 가져오게 할 수 있죠
  • 4:47 - 4:52
    그리고 cmd.equal이 예를 들어 저기 버튼 hi의 이름과 같을 때
  • 4:52 - 4:56
    그리고 cmd.equal이 예를 들어 저기 버튼 hi의 이름과 같을 때
  • 4:56 - 4:58
    이제 처리하고 싶은 대로 할 수 있습니다
  • 4:58 - 5:01
    예를 들면 스크린에 뭔가를 출력해 주던가 하는 거죠
  • 5:01 - 5:05
    이게 이걸 쓰는 한 가지 방법이고요
  • 5:05 - 5:08
    고전적이 방법이기도 하죠
  • 5:08 - 5:09
    지난 시간에 본 겁니다
  • 5:09 - 5:13
    이걸 쓰는 또 다른 방법으로는 getSource를 이용하는 것입니다
  • 5:13 - 5:17
    cmd의 이름을 가져와 hi와 같은지 확인하는 것과 달리
  • 5:17 - 5:21
    e.getSource를 호출하는 방법입니다
  • 5:21 - 5:24
    사실, 이 방법을 사용하면 이 cmd 라인은 더 이상 필요가 없게 됩니다
  • 5:24 - 5:28
    지우지는 않고 코멘트 처리 하겠습니다
  • 5:28 - 5:30
    e.getSource를 하면 오브젝트를 리턴해 준다고 했었죠
  • 5:30 - 5:34
    e.getSource를 하면 오브젝트를 리턴해 준다고 했었죠
  • 5:34 - 5:37
    그럼 저는 이 리턴되는 오브젝트가
  • 5:37 - 5:39
    제 hi 버튼이 맞는 지 확인할 겁니다
  • 5:39 - 5:45
    여기서, 직접적으로 hi와 equal 하는 지 확인하고
  • 5:45 - 5:48
    맞으면 원하는 데로 처리해 줍니다 아까와 똑같이 처리하겠습니다
  • 5:48 - 5:50
    내가 가지고 있는 버튼이 클릭된 hi버튼인지 확인하는 작업입니다
  • 5:50 - 5:52
    내가 가지고 있는 버튼이 클릭된 hi버튼인지 확인하는 작업입니다
  • 5:52 - 5:56
    이 두 가지 방식의 차이는
  • 5:56 - 5:58
    하나는 이름을 문자열로 사용한다는 것이고
  • 5:58 - 6:01
    다른 하나는 실제 오브젝트를 사용한다는 것입니다
  • 6:01 - 6:03
    다른 하나는 실제 오브젝트를 사용한다는 것입니다
  • 6:03 - 6:06
    이제 이게 무엇인지 깊이 생각해봅시다
  • 6:06 - 6:10
    이름을 이용할 때 우리는 실제 오브젝트까지 손 댈 필요가 없었죠
  • 6:10 - 6:12
    이것은 즉 실제 오브젝트를 사용한다면
  • 6:12 - 6:16
    우리는 이것을 인스턴스 변수로 사용할 필요가 없을 거라는 겁니다
  • 6:16 - 6:20
    이것을 인스턴스 변수로서 사용할 일은
  • 6:20 - 6:24
    이것을 아직 사용한 일이 없는 다른 메소드에서 일 겁니다
  • 6:24 - 6:28
    이것을 아직 사용한 일이 없는 다른 메소드에서 일 겁니다
  • 6:28 - 6:31
    예제를 하나 보여드리겠습니다
    코드로 좀 더 구체적으로 알아봅시다
  • 6:31 - 6:33
    자, 코드를 보세요
  • 6:33 - 6:36
    이게 기본적으로 버튼을 만드는 코드 입니다
  • 6:36 - 6:40
    이게 기본적으로 버튼을 만드는 코드 입니다
  • 6:40 - 6:43
    버튼 이름을 hi라고 했고요
  • 6:43 - 6:47
    서쪽 영역에 넣었고요
    그리고 버튼이 클릭되는 상황을 알아챌 수 있게
  • 6:47 - 6:48
    액션 리스너를 add하였습니다
  • 6:48 - 6:50
    버튼이 클릭되면
  • 6:50 - 6:54
    클릭된 버튼이 내가 만든 버튼인지를 확인하고요
  • 6:54 - 6:57
    저쪽의 hi대신에 여기 실제로 호출되는 hi버튼이 있고요
  • 6:57 - 6:58
    이걸 칠판에서는 자리를 좀 덜 차지하게 줄여썼어요
  • 6:58 - 7:03
    클릭된 게 hi버튼이라면
  • 7:03 - 7:05
    화면에 hello가 출력될 겁니다
  • 7:05 - 7:07
    계속해서 이 프로그램을 실행해보죠
  • 7:07 - 7:10
    계속해서 이 프로그램을 실행해보죠
  • 7:10 - 7:13
    hi를 클릭하면 전에 봤던 게 나옵니다
  • 7:13 - 7:14
    hi를 클릭할 때마다 hello가 화면에 뜨죠
  • 7:14 - 7:17
    이제, 이걸 조금 다른 방식으로 활용할 수 있습니다
  • 7:17 - 7:20
    지난 시간에 봤었던 것처럼요
  • 7:20 - 7:22
    자 보세요. add를 할 때. 버튼을 생성하고 그걸 add해 주잖아요
  • 7:22 - 7:26
    자 보세요. add를 할 때. 버튼을 생성하고 그걸 add해 주잖아요
  • 7:26 - 7:30
    한 줄의 코드로요. 왜냐면 버튼을 저장할 변수가 필요 없었기 때문이었습니다
  • 7:30 - 7:34
    여기서는 어떤 액션이벤트인지 소스를 체크할 필요가 없습니다
  • 7:34 - 7:36
    여기서는 어떤 액션이벤트인지 소스를 체크할 필요가 없습니다
  • 7:36 - 7:38
    그냥 액션 이벤트한테 command를 내놓으라고 하는 거에요
  • 7:38 - 7:39
    그냥 액션 이벤트한테 command를 내놓으라고 하는 거에요
  • 7:39 - 7:42
    cmd는 버튼의 이름일 것이고요
  • 7:42 - 7:46
    그러므로 더 이상 실제 버튼 오브젝트의 레퍼런스를 저장하는 변수가 필요 없어지게 됩니다
  • 7:46 - 7:48
    그러므로 더 이상 실제 버튼 오브젝트의 레퍼런스를 저장하는 변수가 필요 없어지게 됩니다
  • 7:48 - 7:51
    왜냐면 이게 내가 필요한 이름을 전달해 주기 때문에요
  • 7:51 - 7:54
    결과적으로, 여기서 인스턴스 변수가 필요없다는 것에 주목해주세요
  • 7:54 - 7:57
    이게 바로 거래입니다
  • 7:57 - 7:59
    이것은 또한 여러분에게 인스턴스 변수가 필요할 때을 구분할 수 있는 통찰력을 줍니다
  • 7:59 - 8:01
    이것은 또한 여러분에게 인스턴스 변수가 필요할 때을 구분할 수 있는 통찰력을 줍니다
  • 8:01 - 8:03
    이런 케이스에는 인스턴스 변수가 필요하고
  • 8:03 - 8:06
    이런 케이스에는 인스턴스 변수가 필요하고
  • 8:06 - 8:10
    아 잘못된 줄이네요
  • 8:11 - 8:14
    인스턴스 변수가 있어야 하는 경우는
  • 8:14 - 8:16
    다른 메소드에서 이 변수를 참조해야 할 경우입니니다
  • 8:16 - 8:18
    다른 메소드에서 이 변수를 참조해야 할 경우입니니다
  • 8:18 - 8:22
    자 이렇게 버튼을 생성했고요
  • 8:22 - 8:24
    이걸 어딘가에 저장(store)했고요
  • 8:24 - 8:27
    이걸 다른 메소드에서 참조할 수 있어야 합니다
  • 8:27 - 8:28
    그래서 인스턴스 변수가 필요해 지는 겁니다
  • 8:28 - 8:31
    만약 다른 메소드에서 이것을 참조할 필요가 없다면
  • 8:31 - 8:34
    만약 다른 메소드에서 이것을 참조할 필요가 없다면
  • 8:34 - 8:37
    두 번 째 경우처럼 되는 것이죠
  • 8:37 - 8:41
    자 이렇게 참조가 필요 없는 경우에는 이걸 저장할 필요도 없죠
  • 8:41 - 8:48
    여기에 대해 질문?
  • 8:54 - 8:57
    그게 학생의 로직 내의 버그(오류)입니다
    컴퓨터는 두 버튼에 동시에 같은 이름을 주었을 경우
  • 8:57 - 9:00
    사용자가 둘 중 어떤 버튼을 이용한 것인지 알아내려고 하지 않습니다
  • 9:00 - 9:02
    난 모른다 이런 식이죠
  • 9:02 - 9:04
    그게 문제를 발생시켜요 그러니까 이런 짓은 하지 마세요
  • 9:04 - 9:08
    이렇게 해서 어떤 일이 일어나는 지 궁금하다면 한 번 시도해 보시고요
  • 9:08 - 9:11
    이것은 컴퓨터 실행의 오류가 아니라 논리적 오류입니다
  • 9:11 - 9:18
    또 다른 질문 있나요? 네?
  • 9:19 - 9:22
    그런 식의 접근도 이 케이스와 비슷합니다
    실제 버튼을 얻는 거죠
  • 9:22 - 9:26
    여기서 변수를 만들기 않으면 이게 뭘 리턴 할까요?
  • 9:26 - 9:29
    여기서 변수를 만들기 않으면 이게 뭘 리턴 할까요?
  • 9:29 - 9:33
    여전히 우리가 만든 오브젝트의 레퍼런스를 리턴해 줄 겁니다
  • 9:33 - 9:36
    이제 문제는 뭐냐면 이제 어떤 오브젝트와 equal한 것인 가를 확인할 방도가 없다는 겁니다
  • 9:36 - 9:39
    이걸 인스턴스 변수로 만들기 않았다면요
  • 9:39 - 9:42
    이게 hi버튼과 같은 것인지 확인할 수가 없어요
  • 9:42 - 9:46
    그러므로 hi버튼을 여기 생성하면 즉각적으로 이것이 add되서 그 후에는 기록을 추적할 수 없게 됩니다
  • 9:46 - 9:47
    그러므로 hi버튼을 여기 생성하면 즉각적으로 이것이 add되서 그 후에는 기록을 추적할 수 없게 됩니다
  • 9:47 - 9:48
    이 녀석은 hi버튼에 대한 포인터를 리턴해 주고요
  • 9:48 - 9:51
    그래서 여러분이 “좋았어, hi버튼의 포인터를 얻었어”라고 할 수 있게 되는 겁니다
  • 9:51 - 9:52
    그래서 여러분이 “좋았어, hi버튼의 포인터를 얻었어”라고 할 수 있게 되는 겁니다
  • 9:52 - 9:55
    이게 hi버튼이걸 어떻게 아냐고 묻는다면 알 수 없습니다
  • 9:55 - 9:56
    이게 hi버튼이걸 어떻게 아냐고 묻는다면 알 수 없습니다
  • 9:56 - 9:59
    이걸 실제 hi버튼과 비교할 방법이 없어요
  • 9:59 - 10:02
    이게 바로 이걸 저장해야 하는 이유랍니다
  • 10:02 - 10:05
    좋아요, 이 두 가지 다른 방식을 어째서 보여주는가?
  • 10:05 - 10:08
    그 이유는 이제 여러분이 상호작용자들을 실제로 활용하게 되면서
  • 10:08 - 10:11
    이러한 측면을 사용하게 될 것이기 때문입니다
  • 10:11 - 10:13
    이러한 측면을 사용하게 될 것이기 때문입니다
  • 10:13 - 10:16
    자 이제 다음으로 할 것은요
  • 10:16 - 10:19
    항상 말하지만 프로그램을 만들 때 항상 유저들이 콘솔창에서 뜨는 게 아니고
  • 10:19 - 10:23
    또 상호작용적으로 쓸 수 있는 텍스트를 마련해 주어야 합니다
  • 10:23 - 10:24
    또 상호작용적으로 쓸 수 있는 텍스트를 마련해 주어야 합니다
  • 10:24 - 10:28
    또 상호작용적으로 쓸 수 있는 텍스트를 마련해 주어야 합니다
  • 10:28 - 10:30
    또 상호작용적으로 쓸 수 있는 텍스트를 마련해 주어야 합니다
  • 10:30 - 10:32
    그러므로 이제 이 예제를 함께 봅시다
  • 10:32 - 10:36
    그러므로 이제 이 예제를 함께 봅시다
  • 10:36 - 10:40
    프로그램에서 textField라 불리는 게 있습니다
  • 10:40 - 10:43
    내 이름이 Mehran이잖아요
  • 10:43 - 10:45
    그럼 hello, Mehran 이렇게 나오고
  • 10:45 - 10:49
    만약 Sally면 hello, Sally이렇게 출력되게 하고 싶어요
  • 10:49 - 10:50
    이걸 텍스트 필드를 이용하여 할 수 있습니다
  • 10:50 - 10:54
    이걸 텍스트 필드를 이용하여 할 수 있습니다
  • 10:54 - 10:56
    이걸 텍스트 필드를 이용하여 할 수 있습니다
  • 10:56 - 10:59
    상호작용자잖아요? 이게 필드 입니다. 콘솔창에 뜨는 거 아닙니다
  • 10:59 - 11:01
    상호작용자잖아요? 이게 필드 입니다. 콘솔창에 뜨는 거 아닙니다
  • 11:01 - 11:04
    그리고 여기에 유저가 뭔가를 써 넣을면 그것을 콘솔창에서 이용하게 해보죠
  • 11:04 - 11:05
    그리고 여기에 유저가 뭔가를 써 넣을면 그것을 콘솔창에서 이용하게 해보죠
  • 11:05 - 11:07
    그리고 여기에 유저가 뭔가를 써 넣을면 그것을 콘솔창에서 이용하게 해보죠
  • 11:10 - 11:12
    자 이걸 어떻게 만들까요?
  • 11:12 - 11:14
    일단 text field라 불리는 상호작용자를 만들어야겠죠
  • 11:14 - 11:18
    일단 text field라 불리는 상호작용자를 만들어야겠죠
  • 11:18 - 11:22
    기본적으로, 텍스트 필드는 여러분이 봤던 겁니다
  • 11:22 - 11:26
    텍스트를 입력할 수 있는 공간이 있는 상호작용자입니다
  • 11:26 - 11:29
    이것이 컨트롤바에 뜨고 그 안에서 엔터를 치면 액션 이벤트가 일어나게 되는 겁니다
  • 11:29 - 11:31
    이것이 컨트롤바에 뜨고 그 안에서 엔터를 치면 액션 이벤트가 일어나게 되는 겁니다
  • 11:31 - 11:35
    여러분이 텍스트와 관련된 뭔가를 만들 고 싶다면 이게 바로 그 기본입니다
  • 11:35 - 11:37
    여러분이 텍스트와 관련된 뭔가를 만들 고 싶다면 이게 바로 그 기본입니다
  • 11:37 - 11:42
    만들면 실제로 상자모양이 생깁니다. 그게 다에요
  • 11:42 - 11:46
    만약 거기에 라벨을 add하고 싶다면
  • 11:46 - 11:49
    앞에서 이름을 add해 주었던 것처럼 해주어야 합니다
  • 11:49 - 11:51
    이걸 어떻게 하는지는 잠시 뒤에 보여드리고요
  • 11:51 - 11:54
    자 상자모양이 생기고 그 안에 뭔가를 쓰고 엔터키를 칩니다
  • 11:54 - 11:58
    그럼 잠재적으로 이벤트가 발생합니다.
  • 11:58 - 12:00
    그럼 잠재적으로 이벤트가 발생합니다.
  • 12:00 - 12:04
    이걸 또 어떻게 설정할까요?
  • 12:04 - 12:08
    자 우리가 만들려고 하는 것은 바로 JTextField입니다
  • 12:08 - 12:13
    이전에 봤던 체크박스나 콤보박스 등과 같은 상호작용자고요
  • 12:13 - 12:13
    이것을 JTextField라 합니다
  • 12:13 - 12:15
    저는 이 약자를 따서 TF라고 이름 짓겠습니다
  • 12:15 - 12:17
    저는 이 약자를 따서 TF라고 이름 짓겠습니다
  • 12:17 - 12:22
    자 이걸 새로 하나 생성하는 방법은 new JTextField를 해주는 거고요
  • 12:22 - 12:26
    인자를 줍니다. 여기서 재미있는 게 있죠
  • 12:26 - 12:27
    여러분은 라벨을 주는 것이 아닙니다
  • 12:27 - 12:31
    텍스트 필드는 라벨이 딸려 있지 않아요
    라벨을 별개로 만들어 주어야 하죠
  • 12:31 - 12:35
    여기에 주는 인자는 바로 텍스트 필드의 사이즈 입니다
  • 12:35 - 12:39
    이것이 얼마나 큰지를 텍스트 필드 내에 들어가는 문자의 최대치로 정해 줍니다
  • 12:39 - 12:43
    이것이 얼마나 큰지를 텍스트 필드 내에 들어가는 문자의 최대치로 정해 줍니다
  • 12:43 - 12:47
    만약 폰트를 설정해 준다면 사이즈는 10M이 됩니다
  • 12:47 - 12:50
    여기서 M은 그 폰트의 가장 넓은 문자입니다
  • 12:50 - 12:53
    모를까 봐 알려드려요
  • 12:53 - 12:57
    모를까 봐 알려드려요
  • 12:57 - 12:58
    모를까 봐 알려드려요
  • 12:58 - 13:00
    사용자가 엔터를 칠 때 말입니다
  • 13:00 - 13:04
    다른 아무 것도 쓰지 않으면 actionPerformed는 오직 버튼에서만 호출되기 때문에
  • 13:04 - 13:05
    다른 아무 것도 쓰지 않으면 actionPerformed는 오직 버튼에서만 호출되기 때문에
  • 13:05 - 13:08
    actionPerformed를 호출하지 않을 겁니다
  • 13:08 - 13:12
    그러므로 우리가 해 야 할 것은 텍스트 필드를 만든 후에
  • 13:12 - 13:13
    이 텍스트 필드가 뭔가 액션을 생성한다는 것을 알려주어야 합니다
  • 13:13 - 13:17
    이 텍스트 필드가 뭔가 액션을 생성한다는 것을 알려주어야 합니다
  • 13:17 - 13:21
    이걸 하는 방법은 좀 펑키한데,
  • 13:21 - 13:23
    일단 textfield.addActionLestener를 해주고요
  • 13:23 - 13:25
    textfield.addActionLestener
  • 13:25 - 13:29
    textfield.addActionLestener
  • 13:29 - 13:32
    알겠죠?
  • 13:32 - 13:35
    실제로 이 방식이 모두 낮을 레벨의 의미하기에 걱정할 필요가 없습니다
  • 13:35 - 13:38
    실제로 이 방식이 모두 낮을 레벨의 의미하기에 걱정할 필요가 없습니다
  • 13:38 - 13:39
    여러분이 해야 할 것은 이 텍스트 필드에 액션을 생성할 수 도 있다고 알려주는 거죠
  • 13:39 - 13:40
    여러분이 해야 할 것은 이 텍스트 필드에 액션을 생성할 수 도 있다고 알려주는 거죠
  • 13:40 - 13:43
    그리고 다른 사람들에게 액션을 생성해 주었을 때를 알려주는 겁니다
  • 13:43 - 13:47
    그래서 이걸 넘긴 거에요
  • 13:47 - 13:49
    그래서 이걸 넘긴 거에요
  • 13:49 - 13:52
    하지만 매번 텍스트 필드를 생성할 때마다
  • 13:52 - 13:54
    모든 텍스트 필드에 이걸 해 줄 필요는 없습니다
  • 13:54 - 13:57
    이 addActionListner의 메세지를 독립적으로 전해 주기 때문에요
  • 13:57 - 13:58
    이 addActionListner의 메세지를 독립적으로 전해 주기 때문에요
  • 13:58 - 14:02
    한 번만 해주면 됩니다.
  • 14:02 - 14:03
    하지만 기본적으로 우리는 이제 텍스트 필드도 이러한 액션이벤트를 생성할 수 있도록 만들어 준 것입니다
  • 14:03 - 14:05
    하지만 기본적으로 우리는 이제 텍스트 필드도 이러한 액션이벤트를 생성할 수 있도록 만들어 준 것입니다
  • 14:05 - 14:09
    하지만 기본적으로 우리는 이제 텍스트 필드도 이러한 액션이벤트를 생성할 수 있도록 만들어 준 것입니다
  • 14:09 - 14:13
    러므로 이걸 생성한 뒤 이 줄을 설정하고 이걸 프로그램의 어딘 가에 add해 주어야 하는 데요
  • 14:13 - 14:17
    프로그램 내에서, add TF를 해주어야 합니다
  • 14:17 - 14:19
    프로그램 내에서, add TF를 해주어야 합니다
  • 14:19 - 14:23
    add TF를 서쪽 영역에 해줍시다
  • 14:23 - 14:25
    지금까지 그랬던 것처럼요
  • 14:25 - 14:30
    누구간 TF에 대고 엔터키를 치면 액션이벤트에 대한 혹은 액션 이벤트를 넘겨주는 액션퍼폼드에 대한 호출이 생성됩니다
  • 14:30 - 14:35
    누구간 TF에 대고 엔터키를 치면 액션이벤트에 대한 혹은 액션 이벤트를 넘겨주는 액션퍼폼드에 대한 호출이 생성됩니다
  • 14:35 - 14:37
    자 이렇게 설정되었을 때
  • 14:37 - 14:40
    이 이벤트를 생성한 텍스트 필드가 무엇인지 어떻게 알죠?
  • 14:40 - 14:44
    여러 개의 텍스트 필드가 있고
  • 14:44 - 14:47
    그 중 하나에 사용자가 엔터를 쳐넣을 때요
  • 14:47 - 14:51
    e.getSource를 해주면 되죠
  • 14:51 - 14:55
    자 이 안에, e.getSource 가 TF와 equal한 지 알아보는 코드를 씁니다
  • 14:55 - 14:58
    자 이 안에, e.getSource 가 TF와 equal한 지 알아보는 코드를 씁니다
  • 14:58 - 15:00
    자 이 안에, e.getSource 가 TF와 equal한 지 알아보는 코드를 씁니다
  • 15:00 - 15:04
    여기서, 모든 종류의 경고창이 뜹니다
  • 15:04 - 15:07
    그러므로 여기서, 우리는 박스에 들어있는 텍스트와 hi를 합쳐서 println해 주고 싶은 건데요
  • 15:07 - 15:12
    이걸 하는 방법을 이 텍스트 필드의 이름.getText를 해주면 됩니다
  • 15:12 - 15:15
    이걸 하는 방법을 이 텍스트 필드의 이름.getText를 해주면 됩니다
  • 15:15 - 15:21
    그럼 알아서 텍스트를 리턴해 줄 겁니다
  • 15:21 - 15:24
    엔터를 치면 박스에 있던 문자열을 리턴해 주죠
  • 15:24 - 15:27
    그럼 hi와 이 리턴된 텍스트를 출력해 줍니다
  • 15:27 - 15:30
    프로그램에서 봤던 것과 같습니다
  • 15:30 - 15:33
    그건 hi가 아니라 hello였다는 걸 제외하면요
  • 15:33 - 15:34
    그건 hi가 아니라 hello였다는 걸 제외하면요
  • 15:34 - 15:38
    하지만 경고음 사라져야 합니다
  • 15:38 - 15:44
    이렇게 코드를 써서 생기는 문제는 뭘까요?
  • 15:44 - 15:47
    이건 인스턴스 변수가 아닙니다. 그렇죠?
  • 15:47 - 15:51
    그러므로 현재는 방도가 없어요
  • 15:52 - 15:57
    여기 이게 init메소드고 이 밖에서 TF를 참조하려면요
    그래서 인스턴스 변수를 생성해야 하는 것입니다
  • 15:57 - 15:59
    알겠죠? 이게 init메소드고요 이 앞은 public void고요
  • 15:59 - 16:04
    이 TF를 클래스 어딘가에서 예를 들어 여기서요
  • 16:04 - 16:08
    내가 l바를 선언한 곳이죠
  • 16:08 - 16:08
    클래스 아래쪽 어딘가 입니다
  • 16:08 - 16:12
    여기다 private JTextField TF를 해줍니다
  • 16:12 - 16:13
    private JTextField TF
  • 16:13 - 16:14
    private JTextField TF
  • 16:14 - 16:15
    private JTextField TF
  • 16:15 - 16:19
    그리고 여기서는 선언은 안하고 tf를 new로 생성해 줍니다
  • 16:19 - 16:23
    이렇게 인스턴스 변수를 선언했습니다
  • 16:23 - 16:26
    이렇게 인스턴스 변수를 선언했습니다
  • 16:26 - 16:27
    여기 버튼 예제에서 보시는 것처럼요. 이게 텍스트 필드라는 것만 빼면 동일합니다
  • 16:27 - 16:29
    여기 버튼 예제에서 보시는 것처럼요. 이게 텍스트 필드라는 것만 빼면 동일합니다
  • 16:29 - 16:35
    그럼 코드를 좀 보여드릴게요
  • 16:35 - 16:39
    자 이게 텍스트 필드 예제입니다
  • 16:39 - 16:42
    콘솔 프로그램을 확장시키려고 합니다
  • 16:42 - 16:44
    아직 콘솔로 하고 있잖아요
  • 16:44 - 16:48
    init메소드에서 name field를 만들게요
  • 16:48 - 16:52
    nameField가 뭐냐고요? private JTextField입니다.
  • 16:52 - 16:55
    이렇게 nameField를 정장해놓고요. 이걸 new JTextFiedl(10)으로 초기화 하겠습니다
  • 16:55 - 16:58
    저기서 썼던 거랑 똑같을 코드죠
  • 16:58 - 17:01
    이제 추가적으로 좀 더 재밌는 걸 해보죠
  • 17:01 - 17:06
    박스에 라벨을 붙이려고 합니다
  • 17:06 - 17:11
    일단 박스를 컨트롤 바에 붙이고
  • 17:11 - 17:13
    name이라는 new JLabel을 add해 줄 겁니다
  • 17:13 - 17:17
    name이라는 new JLabel을 add해 줄 겁니다
  • 17:17 - 17:18
    그 텍스트가 name이고요. 이걸 서쪽 콘트롤바에 add하겠습니다.
  • 17:18 - 17:20
    그 텍스트가 name이고요. 이걸 서쪽 콘트롤바에 add하겠습니다.
  • 17:20 - 17:23
    자 첫째로 이건 그냥 name이라고 써질 거고
  • 17:23 - 17:28
    그리고 아까의 nameField를 add할게요
  • 17:28 - 17:30
    즉 name텍스트 옆에 박스를 생성하는 거죠
  • 17:30 - 17:32
    그리고 아까 말했던 것과 정확히 동일 하게 할겁니다
  • 17:32 - 17:35
    액션리스너를 add해 주고 해서
  • 17:35 - 17:37
    당신이 무엇인가
  • 17:37 - 17:38
    상호작용을 하면
  • 17:38 - 17:42
    그것을 알 수 있게 하는 겁니다
  • 17:44 - 17:47
    . 이것은 즉 이제 actionPerformed가 호출되고
  • 17:47 - 17:50
    액션리스너에 대한 이벤트를 생성하는 것이
  • 17:50 - 17:52
    가능해진다는 이야기입니다
  • 17:52 - 17:55
    actionPerformed에서 e.getSource를 해주고요
    이걸 nameField와 비교할 수 있습니다
  • 17:55 - 17:58
    이걸 밑에 인스턴스 변수로 저장해 두었으니까요
  • 17:58 - 18:02
    hello를 써주고 이걸 nameField의 텍스트와 연계시켜야죠
  • 18:04 - 18:06
    텍스트 크기를 좀 더 키워볼게요
  • 18:06 - 18:09
    자, 조금 더 크게요 어떻게 하는지 보세요
  • 18:09 - 18:11
    제가 좋아하는 서체인Courier 24포인트로 할 게요
  • 18:11 - 18:15
    제가 좋아하는 서체인Courier 24포인트로 할 게요
  • 18:15 - 18:17
    좋아요 더 크게
  • 18:22 - 18:25
    자 다시 한 번
  • 18:25 - 18:29
    Mahran 하고 엔터치면 hello, Mehran이 뜹니다. 보이죠?
    엔터를 칠 때마다 이벤트가 일어나죠.
  • 18:29 - 18:33
    엔터, 엔터, 엔터. 보세요, 텍스트가 나오죠
  • 18:33 - 18:37
    그리고 이건 또 다른 거. 재밌죠
  • 18:37 - 18:39
    Sally... 스크롤을 움직여요. 많이 재미있진 않죠
  • 18:39 - 18:44
    2분정도 하기에 딱 좋아요
  • 18:45 - 18:49
    이런 식으로 하는 거에요 이제 텍스트 박스로부터
  • 18:49 - 18:50
    정보(텍스트)를 얻는 방법을 아셨죠
  • 18:50 - 18:52
    텍스트 박스에 대해 질문?
  • 18:52 - 18:56
    네, 뒤에 학생
  • 18:56 - 19:00
    네, 기본적으로 레이아웃은 뭔가를 add해 줄 때마다
  • 19:03 - 19:07
    왼쪽에서 오른 쪽으로 쭉 확장됩니다
  • 19:07 - 19:11
    어떤 영역이던 간에요 이 경우에는, 서쪽영역이죠
  • 19:11 - 19:14
    모든 게 가운데로 몰렸죠. 여기에 공간을 주고 싶다면 JLabel을 더해주면 됩니다 그러면 이것들 사이에 공간이 더 넓어지겠죠
  • 19:14 - 19:18
    거기까지 못 던지겠네요. 여기 놔둘 테니, 수업 끝나고 집어가세요
  • 19:18 - 19:20
    거기까지 못 던지겠네요. 여기 놔둘 테니, 수업 끝나고 집어가세요
  • 19:20 - 19:23
    또 다른 재미있는 게 있습니다
  • 19:23 - 19:26
    사실 텍스트 필드에 이름을 줄 수 있습니다
  • 19:26 - 19:29
    이런 getSource하고 인스턴스 변수 만들고 하는 거 잘 모르겠어요 하시면
  • 19:29 - 19:32
    이런 getSource하고 인스턴스 변수 만들고 하는 거 잘 모르겠어요 하시면
  • 19:32 - 19:35
    이름을 줘서 그 이름으로 참조해 봅시다
  • 19:35 - 19:39
    괜찮죠? 이름을 만들 수 있어요
  • 19:39 - 19:42
    여기 완전히 똑같은 예제가 있습니다
    약간의 차이가 있지만
  • 19:42 - 19:43
    조금 달라요
  • 19:43 - 19:48
    전과 동일한 코드입니다
  • 19:48 - 19:50
    내가 namefield를 생성했다는 걸 빼면요
  • 19:50 - 19:53
    여기에 액션 코맨드를 주는데요
  • 19:53 - 19:58
    그 액션 코맨드는 name일 것입니다
  • 19:58 - 20:02
    그리고 이런 이벤트를 생성할 때마다 그
  • 20:02 - 20:05
    이벤트의 근원이 얘인지 확인합니다
  • 20:05 - 20:06
    혹은, 이름을 주고
  • 20:06 - 20:11
    버튼에 했던 것과 똑같은 일을 할 수 있어요
  • 20:11 - 20:15
    이 밑에서 getActionCommand를 하고요 이건 문자열을 반환하죠
  • 20:15 - 20:16
    즉 이벤트를 생성하는 오브젝트의 이름을요
  • 20:16 - 20:21
    이게 name과 equal하나 봅니다
    즉 내가 주었던 이름과요
  • 20:21 - 20:23
    버튼에서 했던 걸 돌아볼 수 있어요
  • 20:23 - 20:27
    버튼에서는 항상 이름을 주고 그 이름으로 확인하잖아요
  • 20:27 - 20:28
    버튼에서는 항상 이름을 주고 그 이름으로 확인하잖아요
  • 20:28 - 20:30
    혹은 버튼의 소스로도 확인 해 볼 수 있었죠
  • 20:30 - 20:32
    혹은 버튼의 소스로도 확인 해 볼 수 있었죠
  • 20:32 - 20:35
    JTextField. 이걸 거의 항상 getSource를 사용해 이용할 수 있어요
  • 20:35 - 20:39
    하지만 이름으로도 참조할 수 있고요
  • 20:39 - 20:42
    하지만 실제 화면상에 이 이름은 보이지 않습니다
  • 20:42 - 20:46
    하지만 실제 화면상에 이 이름은 보이지 않습니다
  • 20:46 - 20:47
    화면상에 뭔가 텍스트가 뜨길 바란다면
  • 20:47 - 20:51
    여전히 분리된 라벨에 이름을 써서 만들어 줘야 합니다
  • 20:51 - 20:52
    여전히 분리된 라벨에 이름을 써서 만들어 줘야 합니다
  • 20:52 - 20:59
    여전히 분리된 라벨에 이름을 써서 만들어 줘야 합니다
  • 21:01 - 21:04
    이게 최대치입니다
  • 21:04 - 21:09
    이게 최대치입니다
  • 21:09 - 21:13
    네, namefield는 l바에 있어요
  • 21:13 - 21:17
    더 이상 참조하지 않으니까 필요 없어요
  • 21:17 - 21:21
    이걸 복사해서 붙여 넣기 해볼 게요
  • 21:21 - 21:23
    이걸 복사해서 붙여 넣기 해볼 게요
  • 21:28 - 21:33
    아 이런. 이게 바로 이걸 여기 썼던 이유입니다
  • 21:33 - 21:37
    아 이런. 이게 바로 이걸 여기 썼던 이유입니다
  • 21:37 - 21:40
    이 텍스트를 얻기 위해
  • 21:40 - 21:41
    이걸 참조할 필요가 있죠
  • 21:41 - 21:44
    솔직히, 이걸 e.getSource로 처리해도 됩니다. 이 텍스트를 얻는 걸요
  • 21:44 - 21:45
    그래서 꼭 필요하지 않지만, 이게 나아요
  • 21:45 - 21:49
    이게 훨씬 깔끔한 방법이거든요
  • 21:49 - 21:50
    이걸 없애 버리죠
  • 21:50 - 21:52
    이걸 없애 버리죠
  • 21:53 - 22:00
    JTextField에 대해 또 다른 질문?
  • 22:02 - 22:04
    어.. 네
  • 22:04 - 22:05
    네, 할 수 있어요
  • 22:05 - 22:10
    20분 뒤에 보여드릴게요
  • 22:10 - 22:13
    세 자리 옆으로 날라갔네요..
    이걸 하기 전에 앞서
  • 22:13 - 22:15
    지금까지와는 다른 걸 배워봅시다
  • 22:15 - 22:18
    지금까지는 상호작용자들이
  • 22:18 - 22:20
    스크린 아래쪽에서
  • 22:20 - 22:23
    가운데 정렬되어 나와잖아요
  • 22:23 - 22:26
    이걸 다른 식으로 배치할 수 있을까요
    그리고 이러한 걸 가능하게 해주는 것을
  • 22:26 - 22:30
    그리고 이러한 걸 가능하게 해주는 것은
  • 22:30 - 22:35
    이상하게도 레이아웃layout입니다
  • 22:35 - 22:39
    즉 레이아웃이 특정 상호작용자들의 레이아웃을 컨트롤합니다
  • 22:39 - 22:43
    지금까지 여러분이 여러분의 친구, 콘솔 프로그램
  • 22:43 - 22:45
    혹은 그래픽 프로그램을
  • 22:45 - 22:49
    쓰면서 봤던 것은 보더레이아웃입니다
  • 22:49 - 22:51
    쓰면서 봤던 것은 보더레이아웃입니다
  • 22:51 - 22:55
    사실 여러분은 이미 보더 레이아웃을 경험해 본거죠
    이렇게 생겼습니다
  • 22:55 - 22:59
    가운데 영역이 있고요. 북쪽, 남쪽, 동쪽, 그리고 서쪽 보더border가 있습니다
  • 22:59 - 23:02
    그래서 보더레이아웃이라 부르는 거죠
  • 23:02 - 23:03
    그래서 보더레이아웃이라 부르는 거죠
  • 23:03 - 23:04
    이 보더 레이아웃에서는
  • 23:04 - 23:07
    이 보더 레이아웃에서는
  • 23:07 - 23:12
    가운데 영역에서 액션이 일어났습니다
  • 23:12 - 23:14
    가운데 영역에서 액션이 일어났습니다
  • 23:14 - 23:19
    콘솔 프로그램에서는 자동으로 가운데에 콘솔을 add해 주었고요
  • 23:19 - 23:23
    그게 콘솔 프로그램입니다
    그리고 그래픽 프로그램에서는 G캔버스를 자동으로 가운데에 add해주었습니다
  • 23:23 - 23:26
    그리고 그래픽 프로그램에서는 G캔버스를 자동으로 가운데에 add해주었습니다
    여기서 여러분이 이것저것을 draw할 수 있었죠.
  • 23:26 - 23:30
    다른 영역은 오직 뭔가를 그곳에 add해 주었을 때부터 보이기 시작합니다
  • 23:30 - 23:32
    초기에 오로지 그래픽을 위한
  • 23:32 - 23:36
    그래픽프로그램을 만들 때 여러분은
  • 23:36 - 23:37
    서쪽 영역을 보지 못했습니다
  • 23:37 - 23:39
    그것은 거기에 아무런 상호작용자를 add해 주지 않았기 때문이죠
  • 23:39 - 23:44
    이러한 상호작용자 영역은 무언가 거기에 얹혀주었을 때만 나타납니다
  • 23:44 - 23:47
    이러한 것을 컨트롤바라고 부른다고 했었죠
    지난 시간에 봤잖아요
  • 23:47 - 23:51
    그런 다른 종류의 레이아웃은 무엇이 있을까요?
    중요한 몇 가지 레이아웃을 공부해 봅시다
  • 23:51 - 23:55
    첫째로 그리드 레이아웃이라는 게 있습니다
  • 23:55 - 24:00
    그리드 레이아웃을 이용하려면 일단 이걸 생성해야 하고요
  • 24:00 - 24:04
    또 그리드 레이아웃은 행과 열로 이루어져 있습니다
  • 24:04 - 24:06
    또 그리드 레이아웃은 행과 열로 이루어져 있습니다
  • 24:06 - 24:10
    예를 들어 2행3열로요
  • 24:10 - 24:14
    그럼 이러한 레이아웃이 나옵니다
    이것은 2행 3열을 그리드grid입니다
  • 24:14 - 24:17
    잠시 후에 세부적으로 설명할 때 이걸 만드는 코드를 보여드릴 게요
  • 24:17 - 24:18
    잠시 후에 세부적으로 설명할 때 이걸 만드는 코드를 보여드릴 게요
  • 24:18 - 24:20
    어쨌든 Conceptually개념적으론 이렇습니다
  • 24:20 - 24:24
    자, 이제 아이템을 add할 때 레이아웃을 그리드레이아웃으로 설정해 주어야 합니다
  • 24:24 - 24:26
    자, 이제 아이템을 add할 때 레이아웃을 그리드레이아웃으로 설정해 주어야 합니다
  • 24:26 - 24:31
    그렇게 하면 이제 아이템, 여기서 아이템은 상호작용자를 뜻하고요
  • 24:31 - 24:32
    그렇게 하면 이제 아이템, 여기서 아이템은 상호작용자를 뜻하고요
  • 24:32 - 24:37
    아이템은 맨 위 왼쪽부터 차례로 추가가 됩니다
  • 24:37 - 24:38
    아이템은 맨 위 왼쪽부터 차례로 추가가 됩니다
  • 24:38 - 24:42
    매번 새 요소를 더할 때 마다 그 행의 맨 마지막 열에 찰 때 까지 차례로 채워지고
  • 24:42 - 24:46
    자동으로 아래 행으로 내려갑니다
    순차적으로 채워집니다
  • 24:46 - 24:47
    순차적으로 채워집니다
  • 24:47 - 24:50
    그리드에 차근차근요
  • 24:50 - 24:53
    그럼 그리드 레이아웃이 실제로 어떻게 생겼는지 보여줄게요
  • 24:53 - 24:56
    그럼 그리드 레이아웃이 실제로 어떻게 생겼는지 보여줄게요
  • 25:00 - 25:04
    그리드 레이아웃을 보여주는 심플한 프로그램입니다
  • 25:04 - 25:06
    일단 init메소드에서 레이아웃을 생성해줍니다
  • 25:06 - 25:08
    저는 원래 있던 레이아웃을
  • 25:08 - 25:12
    다시 2,3을 인자로 가진 new GridLayout으로 만들어 주고 싶습니다
  • 25:12 - 25:16
    다시 2,3을 인자로 가진 new GridLayout으로 만들어 주고
  • 25:16 - 25:20
    즉 2행 3열의 그리드로요
  • 25:20 - 25:20
    이 프로그램에서 흥미로운 점은
    이 그리드 레이아웃 예제를 보시면요
  • 25:20 - 25:23
    이건 콘솔 프로그램을 확장한 것이 아닙니다
  • 25:23 - 25:27
    그래픽 프로그램을 확장한 것도 아닙니다
  • 25:27 - 25:29
    그럼 뭘까요? 제가 한 것은 프로그램 자체를 확장한 것입니다
  • 25:29 - 25:31
    그럼 뭘까요? 제가 한 것은 프로그램 자체를 확장한 것입니다
  • 25:31 - 25:35
    콘솔을 생성하지 마라, G캔버스도 생성하지마 이렇게 한 거에요
  • 25:35 - 25:39
    콘솔을 생성하지 마라, G캔버스도 생성하지마 이렇게 한 거에요
  • 25:55 - 25:57
    제가 이걸 만든 이유는
  • 25:57 - 26:02
    그냥 크고 뚱뚱한 버튼들이 보고 싶어서였어요
  • 26:05 - 26:08
    보세요. 6개 버튼이 화면을 완전 차지했죠
  • 26:08 - 26:09
    좋습니다
  • 26:09 - 26:12
    이게 그리드 입니다. 상호작용자들이 그리드를 꽉 채웠어요
  • 26:12 - 26:16
    이 레이아웃은 화면에서 가능한 한 많은 공간을 차지합니다
  • 26:16 - 26:20
    더 중요한 것은 그리드 레이아웃의 각 칸을 차지한
  • 26:20 - 26:24
    상호자용자들이 그 칸의 공간을 최대한 많이 차지한다는 것입니다
  • 26:25 - 26:29
    그래서 이런 모양이 됩니다 이렇게 차리를 차지하죠
  • 26:29 - 26:34
    이게 도대체 뭐지 하는 생각이 들 겁니다
  • 26:34 - 26:37
    이게 도대체 뭐지 하는 생각이 들 겁니다
  • 26:37 - 26:40
    이런 2인치x3인치만한 버튼 같은 거 필요 없다고요
  • 26:40 - 26:42
    이 이유에 대해선 지금 이야기 하지 않겠어요
  • 26:42 - 26:43
    아마 나중에요
  • 26:43 - 26:48
    사운드 이펙트랑 비슷해요
  • 26:48 - 26:53
    제가 창을 리사이즈 할 테니 한 번 보세요
  • 26:53 - 26:53
    모든 버튼은 작고 귀여워요
  • 26:53 - 26:58
    이게 바로 우리가 레이아웃 매니저를 이용하는 이유입니다
  • 26:58 - 26:59
    레이아웃이 어떻게 나올지 알 수 있죠
  • 26:59 - 27:03
    이걸로 사용자가 창을 리사이징할 때의 화면을 컨트롤 할 수 있습니다
  • 27:03 - 27:05
    이걸로 사용자가 창을 리사이징할 때의 화면을 컨트롤 할 수 있습니다
  • 27:05 - 27:08
    이러한 것들이 어떻게 놓일지는 알아야 합니다
  • 27:08 - 27:11
    만약 필요한 것보다 더 많은 공간을 줘도 그리드 레이아웃에서는 그냥 차지해 버립니다
  • 27:11 - 27:15
    만약 필요한 것보다 더 많은 공간을 줘도 그리드 레이아웃에서는 그냥 차지해 버립니다
  • 27:15 - 27:17
    그리드 레이아웃은 그렇게 유용하진 않죠. 볼 만은 하죠. 책을 보면 알 거에요
  • 27:17 - 27:19
    거기 보면 테이블 레이아웃이라는
  • 27:19 - 27:21
    또 다른 종류의 레이아웃이 있습니다
  • 27:21 - 27:24
    또 플로우 레이아웃이라는 것도 있죠
    이것은 이야기 하지 않을 거에요
  • 27:26 - 27:28
    하지만 테이블 레이아웃이라는 게 있다는 거 정도 알아두세요
  • 27:28 - 27:34
    테이블 레이아웃은 그리드 레이아웃과 거진 비슷합니다
  • 27:34 - 27:37
    그리드 레이아웃에서처럼 행과 열을 설정해 주고
  • 27:37 - 27:40
    거기에 차례로 상호작용자를 채워넣을 수 있습니다
  • 27:40 - 27:43
    차이점은 한 칸에서 상호작용자가 자신이 필요한 만큼만의 공간을 차지한다는 것입니다
  • 27:43 - 27:47
    차이점은 한 칸에서 상호작용자가 자신이 필요한 만큼만의 공간을 차지한다는 것입니다
  • 27:47 - 27:49
    차이점은 한 칸에서 상호작용자가 자신이 필요한 만큼만의 공간을 차지한다는 것입니다
  • 27:49 - 27:50
    무슨 뜻이냐고요
  • 27:50 - 27:54
    즉 이 부분에 그리드 레이아웃이 아니고
  • 27:54 - 27:56
    테이블 레이아웃을 대신 생성해서 프로그램을 돌리면요
  • 27:56 - 28:00
    테이블 레이아웃을 대신 생성해서 프로그램을 돌리면요
  • 28:00 - 28:04
    import할 게 더 생기네요
  • 28:04 - 28:06
    이걸 import해줄게요
  • 28:06 - 28:12
    이걸 import해줄게요
  • 28:31 - 28:34
    자 나와라 테이블 레이아웃
  • 28:40 - 28:41
    테이블 레이아웃의 더 좋을 예를 보여줄게요
  • 28:41 - 28:48
    테이블 레이아웃의 더 좋을 예를 보여줄게요
  • 28:50 - 28:51
    가끔은 코드가 이렇게 추해질 때가 있어요
  • 28:51 - 28:54
    가끔은 코드가 이렇게 추해질 때가 있어요
  • 28:54 - 28:57
    어쩔 수 없어요
  • 28:57 - 28:58
    테이블 레이아웃?
  • 28:58 - 29:00
    나왔네요.
  • 29:00 - 29:01
    여전히 6개 버튼이 있죠
  • 29:01 - 29:05
    윈도우도 리사이징 할 수 있고요
  • 29:05 - 29:07
    하지만 이제 창의 사이즈가 바뀌어도 버튼 사이즈는 그대로 입니다
  • 29:07 - 29:10
    영역을 꽉 채우지 않아요
  • 29:10 - 29:13
    그래서 테이블 레이아웃이 그리드 레이아웃보다 아주 조금 더 유용하긴 합니다
  • 29:13 - 29:15
    자 이제 문제는 버튼과 텍스트 필드를 연계시켜서 좀 더 멋진 걸 만들 수 있냐 이겁니다
  • 29:15 - 29:19
    자 이제 문제는 버튼과 텍스트 필드를 연계시켜서 좀 더 멋진 걸 만들 수 있냐 이겁니다
  • 29:19 - 29:23
    자 이제 문제는 버튼과 텍스트 필드를 연계시켜서 좀 더 멋진 걸 만들 수 있냐 이겁니다
  • 29:23 - 29:26
    사실, 할 수 있죠 그리고 이걸 좀 더 재미지게 보여드릴게요
  • 29:26 - 29:29
    이건 온도 전환 프로그램입니다
  • 29:29 - 29:32
    책에 있는 거고요 코드를 따로 보여주진 않겠어요
  • 29:32 - 29:36
    책에 있으니까. 따로 프린트물을 나눠주지 않아요
  • 29:36 - 29:39
    기본적인 개념은 degree Fahrenheit라고 써진 라벨을 주고요
  • 29:39 - 29:41
    또 degree Celsius라는 라벨도 만들어요
  • 29:41 - 29:44
    그리고 이 안에 값을 주고요
    Fahrenheit를 누르면 Celsiusfh 변환해 주는 겁니다
  • 29:44 - 29:45
    Fahrenheit를 누르면 Celsiusfh 변환해 주는 겁니다
  • 29:45 - 29:46
    Celsius에 자동으로 알맞는 값이 채워집니다
  • 29:46 - 29:51
    32F는 0C고요
  • 29:51 - 29:53
    또 다른 재밌는 건 굳이 버튼을 누르지 않아도 되게 하는 겁니다
  • 29:53 - 29:56
    값을 쳐 주고 엔터를 누르면 버튼을 누른 것과 똑 같이 됩니다
  • 29:56 - 29:58
    값을 쳐 주고 엔터를 누르면 버튼을 누른 것과 똑 같이 됩니다
  • 30:00 - 30:03
    재밌죠. 이런 프로그램을 어떻게 만들까요
  • 30:03 - 30:07
    첫째로 필요한 건 관리되 것들이 아닙니다
  • 30:07 - 30:10
    다 그리드에 들어 있고요
  • 30:10 - 30:13
    2행 3열의 테이블 레이아웃이 필요합니다
  • 30:14 - 30:17
    여기 놓을 첫 번째 요소는 라벨입니다
  • 30:17 - 30:21
    그리고 텍스트 필드를 넣습니다
  • 30:21 - 30:23
    사실 특별한 텍스트필드를 넣어줄 겁니다
  • 30:23 - 30:25
    두 개의 특성화된 텍스트 필드가 있는데요 인트필드와 더블필드라고 부르는 것이 그것입니다
  • 30:25 - 30:30
    인티저integer 값 혹은 더블double 값을 얻는다는 보장이 있는 걸 제외하면
  • 30:30 - 30:33
    일반 텍스트 필드와 다를 바 없습니다
  • 30:33 - 30:37
    그럼 만약 A를 써넣고 이걸 기온으로 바꾸려고 하면 어떻게 될 지 궁금하시죠
  • 30:37 - 30:41
    이런, 버튼을 잘못 눌렀습니다
  • 30:41 - 30:44
    A를 기온으로 바꾸려고 해요 그럼 정수값을 넣으라는 팝업 창이 뜹니다
  • 30:44 - 30:46
    그럼 여러분은 다시 정수 값을 제대로 넣어야 합니다
  • 30:46 - 30:49
    그럼 여러분은 다시 정수 값을 제대로 넣어야 합니다
  • 30:49 - 30:52
    그리고 버튼을 넣어주는데요
    어떻게든 저는 이 버튼과 텍스트 필드를 연결해 주어서
  • 30:52 - 30:54
    같은 액션을 취하게 하고 싶어요
  • 30:54 - 30:56
    이 코드를 보여 줄게요. 생각보다 훨씬 짧습니다
  • 30:56 - 30:58
    이 코드를 보여 줄게요. 생각보다 훨씬 짧습니다
  • 30:58 - 31:01
    첫째로 할 것은 레이아웃을 테이블 레이아웃으로 설정해 주는 겁니다
  • 31:01 - 31:05
    콘솔이나 캔버스가 생성되는 것을 원치 않기 때문에
  • 31:05 - 31:06
    프로그램을 확장한다는 것에 다시 한 번 주목해주세요
  • 31:06 - 31:08
    저 전체 레이아웃을 명시하고 싶어요
  • 31:08 - 31:10
    그래서 프로그램을 확장하는 겁니다
  • 31:14 - 31:16
    TabelLayout(2,3)로 설정해 주고 그럼 요소가 차례로 들어가게 되죠
  • 31:16 - 31:19
    TabelLayout(2,3)로 설정해 주고 그럼 요소가 차례로 들어가게 되죠
  • 31:19 - 31:20
    TabelLayout(2,3)로 설정해 주고 그럼 요소가 차례로 들어가게 되죠
  • 31:20 - 31:23
    다시 말하지만. 그리고 첫 번째 요소를 add해 주겠습니다
  • 31:23 - 31:26
    . 제가 첫째로 add할 것은
  • 31:26 - 31:28
    바로 degrees Fahrenheit를 라벨로 넣어주는 것입니다
  • 31:28 - 31:31
    그리고 거기에 맞춰 Fahrenheit 필드를 넣어주고요
  • 31:31 - 31:34
    그리고 거기에 맞춰 Fahrenheit 필드를 넣어주고요
  • 31:34 - 31:35
    이걸 어떻게 만들죠? 이 위쪽에 일단 생성해 줍니다
  • 31:35 - 31:39
    바로 인스턴스 변수로써 선언해 준거죠
  • 31:39 - 31:43
    그리고 이건 인트필드입니다
  • 31:43 - 31:44
    J텍스트 필드가 아니고요
  • 31:44 - 31:47
    아까 말했듯이 정수를 써넣어주는 데 특성화된 필드입니다
  • 31:47 - 31:50
    그것 빼고는 텍스트 필드랑 똑같고요
  • 31:50 - 31:55
    일단 인트필드를 보여주고 싶네요
  • 31:55 - 31:56
    자 new intfield를 해주고 이것의 초기 값을, 사이즈가 아니고요
  • 31:56 - 31:59
    초기값은 32로 설정해 주겠습니다
  • 31:59 - 32:02
    Fahrenheit필드를요
  • 32:02 - 32:04
    그리고 액션 코멘드를 설정해 줄 건데요
  • 32:04 - 32:08
    그래서 액션이 생성되면 처리해 줄 수 있게요
  • 32:08 - 32:09
    그래서 액션이 생성되면 처리해 줄 수 있게요
  • 32:09 - 32:11
    그래서 액션이 생성되면 처리해 줄 수 있게요
  • 32:11 - 32:14
    이름과 연관 지어서 F -> C
  • 32:14 - 32:17
    이게 이름이 될 거고요 자 이제 이름도 설정했고요
  • 32:17 - 32:19
    이제 액션 이벤트를 생성할 거라는 걸 알려줍시다
  • 32:19 - 32:22
    이제 액션 이벤트를 생성할 거라는 걸 알려줍시다
  • 32:22 - 32:25
    그리고 액션 리스너를 add해주죠
  • 32:25 - 32:28
    전에 텍스트 필드에 했던 거랑 똑같죠. 이게 인트필드라는 거 빼고요
  • 32:28 - 32:31
    Celsius 필드에도 이와 같은 일을 똑같이 해줍니다. 이것도 인트필드죠
  • 32:31 - 32:36
    이건 처음엔 초기값0으로 시작하고요
    액션코맨드를 C에서 F가 되게 해놨습니다
  • 32:36 - 32:39
    그러므로 약간 다른 이름을 주도록 하죠
  • 32:39 - 32:43
    또한 액션이벤트를 listen하고 생성하도록 설정해 놓았습니다
  • 32:43 - 32:44
    그런 후 그리드에 놓습니다
  • 32:44 - 32:48
    그리드에 놓을 첫 번째 요소는 라벨입니다
  • 32:48 - 32:50
    아까 이야기했듯이요
  • 32:50 - 32:53
    다음 요소는 텍스트 박스고요
  • 32:53 - 32:55
    실제로는 숫자로 된 값을 갖는 거고요
  • 32:55 - 32:58
    그리드 첫째 줄의 마지막 요소는 버튼입니다
  • 32:58 - 33:02
    이름은 F ->C고요
  • 33:02 - 33:06
    여러분은 이렇게 같은 이름을 만들어 놓으면 논리적 충돌이 일어나지 않을까 궁금할 겁니다
  • 33:06 - 33:10
    여러분은 이렇게 같은 이름을 만들어 놓으면 논리적 충돌이 일어나지 않을까 궁금할 겁니다
  • 33:10 - 33:14
    여러분은 이렇게 같은 이름을 만들어 놓으면 논리적 충돌이 일어나지 않을까 궁금할 겁니다
  • 33:14 - 33:17
    여러분은 이렇게 같은 이름을 만들어 놓으면 논리적 충돌이 일어나지 않을까 궁금할 겁니다
  • 33:17 - 33:22
    네 이 두 요소는 같은 이름을 가지고요
    하지만 두 경우 다 같은 일을 해 주고 싶기 때문에
  • 33:22 - 33:25
    별 차이가 없어요
  • 33:25 - 33:28
    제가 원하는 건 누군가 버튼을 누르면 변환이 일어나는 것이니까요
  • 33:28 - 33:30
    이렇게 변환이 일어나는 코드를 쓰고요
  • 33:30 - 33:31
    이렇게 변환이 일어나는 코드를 쓰고요
  • 33:31 - 33:34
    또 누군가 텍스트 필드에 뭔가를 쓰고 엔터를 치면
  • 33:34 - 33:36
    버튼을 누른 것과 같은 일이 생깁니다
  • 33:36 - 33:38
    이것은 여러분이 웹에서 많이 접했던 것과 다르지 않습니다
  • 33:38 - 33:42
    어떠한 검색 엔진에서 창에 뭔가를 치고 클릭을 해서
  • 33:42 - 33:45
    검색이 시작되거나 엔터를 쳐서 검색이 시작되는 거 기억나시죠
    하지만 몇이나 되는 사람이 버튼을 누릅니까
  • 33:45 - 33:48
    없어요
    또 엔터를 치는 사람은 얼마나 되죠?
  • 33:48 - 33:52
    엔터를 치는 게 편하지 않나요?
  • 33:52 - 33:54
    어쨌든 이 프로그램에서도 그것과 같은 작업을 해주는 겁니다
  • 33:54 - 33:57
    엔터를 치는 게 더 편할 때가 있기 때문에
  • 33:57 - 34:01
    우리가 액션 코맨드에 추가적인 작업을 해 주는 거죠
  • 34:01 - 34:04
    그리고 Celcius에도 똑같은 일을 해줍니다
  • 34:04 - 34:08
    이게 전체 UI 혹은 GUI를 위한 설정입니다
  • 34:08 - 34:11
    그리고 사용자가 버튼을 클릭하면 액션 코맨드를 가지고 옵니다
  • 34:13 - 34:17
    그리고 액션리스너를 추가하여
  • 34:17 - 34:19
    처리해 줍니다
  • 34:19 - 34:22
    버튼을 클릭했을 때 넘어오는
  • 34:22 - 34:25
    액션 코맨드가 F->C라면요
  • 34:25 - 34:28
    Fahrenheit 필드에 뭔가 써넣고 엔터를 치거나 버튼을 클릭하면
  • 34:28 - 34:30
    Fahrenheit 필드에 뭔가 써넣고 엔터를 치거나 버튼을 클릭하면
  • 34:30 - 34:33
    값을 갖게 되고
  • 34:33 - 34:37
    F필드는 인티저 필드니까 인티져 값을 반환합니다
  • 34:37 - 34:40
    그리고 수학적인 계산을 좀 해주면 되는 데요
  • 34:40 - 34:42
    그리고 수학적인 계산을 좀 해주면 되는 데요
  • 34:42 - 34:45
    화씨에서 섭씨로 바꾸는 실을 몰라도 너무 걱정하지 마세요
  • 34:45 - 34:48
    이렇게 하면 됩니다 F 곱하기 95를 하고 32를 빼주면 되요
  • 34:48 - 34:51
    이제 알겠죠
  • 34:51 - 34:56
    더 재미있는 것은 이제 C필드에 계산된 값이 들어가는 것입니다
  • 34:56 - 34:58
    더 재미있는 것은 이제 C필드에 계산된 값이 들어가는 것입니다
  • 34:58 - 35:01
    F필드에 값을 넣고 엔터를 치거나 버튼을 누르면
  • 35:01 - 35:02
    화면의 C필드에 값이 업데이트 됩니다
  • 35:02 - 35:06
    같은 것을 말할 때 얼마다 다양하게 표현할 수 있나요
  • 35:06 - 35:07
    누군가 C->F라고 한다면
  • 35:07 - 35:10
    섭씨에서 화씨로 변환하는 식이 필요할 겁니다
  • 35:10 - 35:14
    섭씨에서 화씨로 변환하는 식이 필요할 겁니다
  • 35:14 - 35:16
    섭씨에서 화씨로 변환하는 식이 필요할 겁니다
  • 35:16 - 35:18
    섭씨에서 화씨로 변환하는 식이 필요할 겁니다
  • 35:18 - 35:20
    섭씨에서 화씨로 변환하는 식이 필요할 겁니다
  • 35:24 - 35:27
    이게 전체 프로그램입니다 이건 인스턴스 변수고요
  • 35:27 - 35:28
    그럼 이제 기온 프로그램을 실행해 봅시다
  • 35:28 - 35:31
    그럼 이제 기온 프로그램을 실행해 봅시다
  • 35:31 - 35:32
    레이블이 있고
  • 35:32 - 35:36
    초기 값이 있고 F->C버튼이 있고요
  • 35:36 - 35:39
    그리고 100이란 값을 화씨에 넣어주면
  • 35:39 - 35:40
    38 섭씨로 변화해 줍니다
  • 35:40 - 35:43
    그리고 212를 화씨에 넣어주고
  • 35:43 - 35:45
    마우스를 사용하지 않고, 엔터를 쳐도 마찬가지고 변환이 이루어지고요
  • 35:45 - 35:49
    같습니다
  • 35:49 - 35:52
    섭씨 온도 0. 32. 전체 프로그램을 GUI를 이용해 완성했습니다
  • 35:52 - 35:55
    섭씨 온도 0. 32. 전체 프로그램을 GUI를 이용해 완성했습니다
  • 35:55 - 35:59
    리사이징도 할 수 있고요. 어쨌든 계속 중앙에 위치합니다.
  • 35:59 - 36:02
    멋지지 않나요. 작게 하면 작아지진 않아요
  • 36:07 - 36:11
    볼 수 없으니까. 질문 있나요?
  • 36:11 - 36:13
    마이크를 사용해서 말해줄래요
  • 36:13 - 36:18
    여러분들도 마이크를 쓰게 해야겠네요
  • 36:19 - 36:21
    그리드 각 셀의 넓이를 조정할 수 있나요
  • 36:21 - 36:25
    그래서 테이블 레이아웃이 있죠
  • 36:25 - 36:26
    각각의 사이즈를 특정할 수 있도록 만들 수 있어요
  • 36:26 - 36:30
    각각의 사이즈를 특정할 수 있도록 만들 수 있어요
  • 36:30 - 36:32
    . 여기서 하지 않았지만요. 책에는 있습니다
  • 36:32 - 36:36
    그렇게 하고 싶다면요. 하지만 수업에서는 더 이상 깊게 들어가지 않겠습니다
  • 36:36 - 36:39
    하지만 네 할 수 있는 방법은 있어습니다
  • 36:39 - 36:41
    마지막으로 재밌는 걸 하나 하고 싶네요
  • 36:41 - 36:46
    텍스트와 그래픽을 이용해서요 그리고 상호작용자도요
  • 36:46 - 36:47
    다 이용해서요
  • 36:47 - 36:52
    텍스트, 그래픽, 상호작용자. 옛날에 했던 거 생각이 나죠
    행맨(단어 맞추는 게임)이요
  • 36:52 - 36:54
    행맨. 텍스트도 이용했고 그래픽도 이용했죠
  • 36:54 - 36:55
    하지만 상호작용자는 쓰지 않았었죠. 이제 상호작용자에 대해 배웠으니 버튼 텍스트 등을 이용해서 다시 해봅시다.
  • 36:55 - 36:59
    하지만 상호작용자는 쓰지 않았었죠. 이제 상호작용자에 대해 배웠으니 버튼 텍스트 등을 이용해서 다시 해봅시다.
  • 37:01 - 37:05
    자 이제 모든 걸 합쳐서 해볼 시간이 돌아왔습니다
  • 37:07 - 37:09
    텍스트와 그래픽에요
  • 37:09 - 37:12
    자 이제 텍스트와 그래픽으로 할 것은
  • 37:12 - 37:16
    프로그램에 콘솔을 만들고 그래픽 캔버스도 만들어야 되고요
  • 37:17 - 37:21
    상호작용자도 만들어야 되요.
  • 37:23 - 37:26
    이걸 다 어떻게 할까요
  • 37:26 - 37:28
    첫째로 할 것은 작은 텍스트를 칠판에 써주고요
  • 37:28 - 37:31
    첫째로 할 것은 작은 텍스트를 칠판에 써주고요
  • 38:07 - 38:10
    두 가지 멋진 맛이 합해지면 더 맛있어져요
  • 38:10 - 38:13
    어떤걸 초콜렛으로 하고 어떤걸 땅콩 버터로 할 지만 정해주면 되요
  • 38:13 - 38:17
    하지만 텍스트와 그래픽의 조합이니, 행맨이 됩니다. 상호작용자도 있고요
  • 38:21 - 38:25
    우리가 할 것은 콘솔 창을 확장하는 것입니다
  • 38:25 - 38:29
    우리가 할 것은 콘솔 창을 확장하는 것입니다
  • 38:29 - 38:30
    우리가 여전히 (우리의 친구인)콘솔을 필요로 하기 때문입니다
  • 38:33 - 38:37
    우리가 콘솔 프로그램을 사용할 때, 보더라는 게 있죠
  • 38:37 - 38:38
    우리가 콘솔 프로그램을 사용할 때, 보더라는 게 있죠
  • 38:38 - 38:42
    이것은 우리에게 동서남북 영역을 제공하고요
  • 38:42 - 38:48
    이 영역들에 우리는 상호작용자를 올릴 수 있죠
  • 38:48 - 38:49
    이 영역들에 우리는 상호작용자를 올릴 수 있죠
  • 38:49 - 38:52
    흥미로운 것은 중앙 영역입니다
  • 38:52 - 38:55
    전에 말했던 것처럼 콘솔 프로그램은 중앙 영역을 채우고요
  • 38:55 - 38:59
    전에 말했던 것처럼 콘솔 프로그램은 중앙 영역을 채우고요
  • 38:59 - 39:00
    거기에 텍스트를 쓸 수 가 있죠 그게 할 수 있는 전부이기도 하고요
  • 39:00 - 39:04
    우리가 할 것은 콘솔 프로그램에게 중앙 영역을 주고
  • 39:04 - 39:08
    거기에 다른 레이아웃을 줘서 텍스트나
  • 39:08 - 39:08
    그래픽을 채워넣을 수 있게 만드는 것입니다
  • 39:08 - 39:11
    그래픽을 채워넣을 수 있게 만드는 것입니다
  • 39:11 - 39:13
  • 39:13 - 39:15
    이제 제가 뭘 할거냐고요
  • 39:15 - 39:19
    첫째로 할 것은 레이아웃에 대해 고려하는 것입니다
  • 39:19 - 39:22
    레이아웃은 이 중앙에 적용될 것이고요
  • 39:22 - 39:26
    기억해야 할 것은 콘솔 프로그램입니다
  • 39:26 - 39:29
    콘솔 프로그램은 영역을 꽉 채우고요
  • 39:29 - 39:34
    이제 콘솔에 첫 요소를 추가해 주어야 합니다
  • 39:34 - 39:38
    이것은 즉 레이아웃을 어떻게 정하든 이 안에 적용된다는 것입니다
  • 39:38 - 39:42
    한 줄에 3개의 요소가 들어가는 그리드를 만든다고 하죠
  • 39:42 - 39:44
    첫번째는 콘솔이 될 거고요
  • 39:44 - 39:45
    첫번째는 콘솔이 될 거고요
  • 39:45 - 39:49
    그리고 제어권이 없을 겁니다
    그게 콘솔 프로그램이 원래 그러니까요
  • 39:49 - 39:52
    여러분이 콘솔 프로그램을 확장하고 만들 레이아웃이 뭐던 간에
  • 39:52 - 39:55
    첫 번째 요소는 텍스트입니다
  • 39:57 - 39:59
    그럼 여러분은 궁금하겠죠
  • 39:59 - 40:02
    . 아까 그래픽에 대해서도 언급했는데 콘솔 프로그램을 쓰면 그래픽은 어쩌냐고요
  • 40:02 - 40:04
    . 아까 그래픽에 대해서도 언급했는데 콘솔 프로그램을 쓰면 그래픽은 어쩌냐고요
  • 40:04 - 40:08
    우리는 행맨에 약간의 트릭을 사용할 겁니다
  • 40:08 - 40:09
    G캔버스라는 게 있었잖아요
  • 40:09 - 40:13
    이 G캔버스를 생성할 겁니다. 그리고 레이아웃을 줄거에요
  • 40:13 - 40:16
    이 G캔버스를 생성할 겁니다. 그리고 레이아웃을 줄거에요
  • 40:16 - 40:21
    그러니까 일단 콘솔 프로그램을 생성하고 레이아웃을 생성해 주고요
  • 40:21 - 40:23
    그러니까 일단 콘솔 프로그램을 생성하고 레이아웃을 생성해 주고요
  • 40:23 - 40:30
    예를 들어 인자가 1,3인 그리드 레이아웃을 만들죠
  • 40:30 - 40:31
    이렇게 생길 거고요
  • 40:32 - 40:36
    첫번째 칸은 이미 콘솔이 차지했고요
  • 40:36 - 40:38
    G캔버스를 생성해서 두 번째 칸에 올려줍니다
  • 40:38 - 40:41
    G캔버스를 생성해서 두 번째 칸에 올려줍니다
  • 40:41 - 40:44
    그리고 또 G캔버스를 하나 더 생성해서 여기에 추가시켜 줍니다
  • 40:44 - 40:48
    그리고 또 G캔버스를 하나 더 생성해서 여기에 추가시켜 줍니다
  • 40:48 - 40:54
    이게 G캔버스 도스입니다
  • 40:56 - 41:00
    그러므로 한 개의 콘솔과 두 개의 G캔버스가 생겼습니다
  • 41:00 - 41:03
    추가로, 화면 주변에 상호작용작들을 add해 줄 수 있고요
  • 41:03 - 41:06
    이 시점에서 여러분은 충격과 공포와 환희 등에 빠져야 합니다
  • 41:06 - 41:07
    이 시점에서 여러분은 충격과 공포와 환희 등에 빠져야 합니다
  • 41:07 - 41:11
    이제 5분만에 한 거에요 그것도 엄청 쉽게.
  • 41:11 - 41:18
    자 이게 그 모습입니다
  • 41:19 - 41:22
    텍스트 그리고 그래픽. 콘솔 프로그램을 확장시켰고요
  • 41:22 - 41:24
    그리고 init메소드로 레이아웃을 설정하는 데요
  • 41:26 - 41:31
    저는 그리드 레이아웃으로 하고 싶어요
  • 41:31 - 41:33
    기억하세요 그리드 레이아웃
  • 41:33 - 41:35
    요소들이 공간을 준 만큼 차지해 버려요
  • 41:35 - 41:39
    그게 이번 경우에는 제가 바라는 바고요
  • 41:39 - 41:42
    그래서 그리드를 쓰는 거고요. 1행 3열의 그리드를 만들 거에요
  • 41:42 - 41:46
    그리고 1/3에는 콘솔을 넣을 거고요
  • 41:46 - 41:50
    나머지 두 개에는 캔버스르 넣는 데 하나는 최대한 크게 확장할 거에요
  • 41:50 - 41:52
    나머지 두 개에는 캔버스르 넣는 데 하나는 최대한 크게 확장할 거에요
  • 41:52 - 41:54
    그럼 캔버스 두 개를 생성해야겠죠
  • 41:54 - 41:58
    RightCanvas와 LeftCanvas라고 부를게요
  • 41:58 - 42:01
    RightCanvas와 LeftCanvas라고 부를게요
  • 42:01 - 42:06
    그리고 재미를 위해 텍스트 필드도 하나 넣어주고요
  • 42:06 - 42:08
    이게 상호작용자죠
  • 42:08 - 42:10
    제가 원하는 프로그램은 상호작용자, 텍스트, 그래픽 세 가지요소가 들어가는 거였으니까
  • 42:10 - 42:11
    제가 원하는 프로그램은 상호작용자, 텍스트, 그래픽 세 가지요소가 들어가는 거였으니까
  • 42:11 - 42:16
    RightCanvas와 LeftCanvas라고 부를게요
  • 42:16 - 42:17
    이제 뭘 할 거냐고요
  • 42:17 - 42:21
    그리고 재미를 위해 텍스트 필드도 하나 넣어주고요
  • 42:21 - 42:24
    일단 LeftCanvas에 new Canvas를 해줍니다
  • 42:24 - 42:28
    그리고 add를 할 때 myLayout에 해주고요
  • 42:28 - 42:30
    캔버스 전체를 더할 때는 그리드의 첫번째에 이미 콘솔을 넣기로 했으니 두번째에 넣어줍니다
  • 42:30 - 42:32
    캔버스 전체를 더할 때는 그리드의 첫번째에 이미 콘솔을 넣기로 했으니 두번째에 넣어줍니다
  • 42:32 - 42:33
    캔버스를 add했잖아요. 두번째 요소로
  • 42:33 - 42:37
    그것을 다시 오른쪽 캔버스에 똑같이 해줍니다
  • 42:37 - 42:41
    세번째 요소로 들어가는 오른쪽 캔버스에요
  • 42:41 - 42:43
    그러므로 두 개의 큰 캔버스가 그리드의 두번째와 세번째에 있습니다
  • 42:43 - 42:45
    이제 콘솔, 캔버스, 캔버스 이런 식이죠
  • 42:45 - 42:49
    그럼 이제 상호작용자들을 add하겠어요
  • 42:49 - 42:53
    일단 텍스트 필드를 만들거에요. new JTextField를 해줘야겠죠
  • 42:53 - 42:57
    그리고 private인 인스턴스 변수로 선언할 거고요
  • 42:57 - 42:58
    방금 보여줬고요. 최대 사이즈는 10으로 할 거에요
  • 42:58 - 43:02
    라벨을 add하고요. 라벨은 some text라고 부를게요
  • 43:02 - 43:04
    그리고 서쪽영역에 놓고요
  • 43:05 - 43:09
    이 시점에서 이제 여러분이 잘 알고 사랑하는 액션리스너를 add해 줍니다
  • 43:09 - 43:13
    이 시점에서 이제 여러분이 잘 알고 사랑하는 액션리스너를 add해 줍니다
  • 43:13 - 43:16
    매우 흔히 일어나는 일인데요. 사람들은 텍스트 필드를 생성하고 프로그램에서 뭔가 칩니다
  • 43:16 - 43:19
    그러고 이제 이게 안되요. 그럼 멘붕이 옵니다.
  • 43:19 - 43:21
    그러고 이제 이게 안되요. 그럼 멘붕이 옵니다.
  • 43:21 - 43:25
    머리를 쥐어 뜯으며 고민해요. 바로 액션 리스너를 add해 주는 걸 까먹은 겁니다
  • 43:25 - 43:26
    머리를 쥐어 뜯으며 고민해요. 바로 액션 리스너를 add해 주는 걸 까먹은 겁니다
  • 43:26 - 43:28
    머리를 쥐어 뜯으며 고민해요. 바로 액션 리스너를 add해 주는 걸 까먹은 겁니다
  • 43:28 - 43:31
    알고 배우고 실천하고 사랑하세요
  • 43:31 - 43:35
    그리고 버튼도 두 개 add할 건데요
  • 43:35 - 43:38
    그럼 상호작용자는 텍스트 필드하고 버튼 두 개가 더 있는거죠
  • 43:38 - 43:40
    버튼 하나는 왼쪽 캔버스에 그림을 그릴 거고
    다른 하나는 오른쪽에 그림을 그리게 만들 거에요
  • 43:40 - 43:42
    그럼 나머지를 마저 만들기 전에 이게 어떻게 생겼나 보여드리죠
  • 43:42 - 43:46
    텍스트와 그래픽까지 만들었죠
  • 43:46 - 43:48
    콘솔을 만들었고
  • 43:48 - 43:50
    콘솔을 만들었고
  • 43:50 - 43:55
    현재 경계선은 없지만 두 개의 캔버스가 있습니다
  • 43:55 - 43:58
    두 개의 다른 캔버스 창이 여기 있어요
  • 43:58 - 44:01
    텍스트가 있고요. hi라고 칠 수 있죠
  • 44:01 - 44:03
    hi. 재밌죠?
  • 44:03 - 44:04
    hi. 재밌죠?
  • 44:04 - 44:07
    Draw left는 외족 창에 그림을 그리게
  • 44:07 - 44:08
    사각형을 그릴건데 좀 있다 보여드리기로 하고
  • 44:08 - 44:10
    사각형을 그릴건데 좀 있다 보여드리기로 하고
  • 44:10 - 44:12
    Draw right는 오른쪽 창에 그림을 그릴 수 있게 합니다.
  • 44:12 - 44:16
    이걸 어떻게 할까요? 나머지 프로그램을 만들면서 알아봅시다
  • 44:16 - 44:19
    일단 모든 게 세팅되었어요. 콘솔, 캔버스 두 개.
  • 44:19 - 44:21
    일단 모든 게 세팅되었어요. 콘솔, 캔버스 두 개.
  • 44:21 - 44:24
    여기서 액션이 일어납니다
    actionPerformed가 호출되면 누군가가 상호작용자를 이용해 상호작용한 거죠
  • 44:24 - 44:27
    actionPerformed가 호출되면 누군가가 상호작용자를 이용해 상호작용한 거죠
  • 44:27 - 44:31
    하나의 상호작용자를 가지고 상호작용을 하는 것 외에는
    이 프로그램에서 할 수 있는 게 없습니다
  • 44:31 - 44:35
    일단 텍스트 필드를 체크하고요
  • 44:35 - 44:39
    텍스트 필드와의 상호작용이라면
  • 44:39 - 44:43
    그럼상호작용은 근원지가 텍스트필드 였다면 텍스트 필드에 뭔가를 친 건 이제 콘솔에 나타날 겁니다
  • 44:43 - 44:47
    . println을 하면 항상 콘솔에 나타나게 되어있으니까요
  • 44:47 - 44:50
    여기선 아직 별 재미가 없죠
  • 44:50 - 44:53
    양자택일적으로 텍스트필드에 타이핑을 하지 않았다면
  • 44:53 - 44:56
    버튼을 클릭한 것인데. 이걸 getSource와 getActionCommand로 처리할 수 있습니다
  • 44:56 - 45:00
    버튼을 클릭한 것인데. 이걸 getSource와 getActionCommand로 처리할 수 있습니다
  • 45:00 - 45:03
    이걸 여러분이 원하는 대로 섞어 사용하면 됩니다
  • 45:03 - 45:06
    코맨드(명령)가 뭐였냐 이러면 getActionCommand를 쓰면 되는데
  • 45:06 - 45:10
    그 코맨드가 Draw left였다면 이제 색이 채워진 사각형이 새로 생성되겠죠. 보여드리죠
  • 45:10 - 45:14
    새로운 사각형을 만듭니다
  • 45:14 - 45:18
    간단하죠. 50x20의 크기로요.
  • 45:18 - 45:20
    상수여야 해요
  • 45:21 - 45:23
    그리고 filled(채움)으로 설정해 주고
  • 45:23 - 45:27
    사각형을 반환합니다. 그냥 색을 채운 사각형을 만들어서 옛다 가져라 이런 겁니다
  • 45:27 - 45:28
    사각형을 반환합니다. 그냥 색을 채운 사각형을 만들어서 옛다 가져라 이런 겁니다
  • 45:28 - 45:32
    그리고 이 사각형을 왼쪽 캔버스에 더해 줘야 하는데
  • 45:32 - 45:34
    그리고 이 사각형을 왼쪽 캔버스에 더해 줘야 하는데
  • 45:34 - 45:38
    그냥 그래픽 프로그램이 아니니까요
  • 45:38 - 45:42
    그냥 add하란다고 add해 지지 않아요
  • 45:42 - 45:47
    이걸 더해 주려면 어떤 캔버스에 더할지 명확히 해주어야 합니다
  • 45:47 - 45:52
    왼쪽 캔버스에 더할 거니까 LetfCanvas 이걸 더해라. 이렇게 하고요
  • 45:52 - 45:55
    x좌표 20 y좌표 leftY에 더해줍니다
  • 45:55 - 45:58
    Left Y는 값이 10에서 시작하고요
  • 45:58 - 46:03
    매번 뭔가를 더할 때 마다 원래 Y에서 자리가 아래로 내려갑니다
  • 46:03 - 46:07
    매번 뭔가를 더할 때 마다 원래 Y에서 자리가 아래로 내려갑니다
  • 46:07 - 46:10
    그럼 다음 사각형은 아래쪽에 그려지는 거죠
  • 46:10 - 46:12
    그럼 다음 사각형은 아래쪽에 그려지는 거죠
  • 46:12 - 46:16
    이걸 똑같이 오른쪽에도 해줍니다
  • 46:16 - 46:19
    일단 색을 채운 사각형을 생성한 다음에요
  • 46:19 - 46:23
    분리된 right Y좌표가 있고요
  • 46:23 - 46:24
    계속해서 이 밑으로 그려집니다
  • 46:24 - 46:26
    오른쪽 캔버스의 경우에는요
  • 46:26 - 46:28
    이 차이죠
  • 46:28 - 46:30
    그러므로 프로그램을 실행하면
  • 46:30 - 46:32
    텍스트가 있고요
  • 46:32 - 46:34
    다시 great 라고 쓰고
  • 46:34 - 46:36
    엔터를 누르면
  • 46:36 - 46:40
    이벤트가 발생합니다
    스크린에 println해서 출력을 해주고
  • 46:40 - 46:43
    여기 이벤트를 생성하고요
  • 46:43 - 46:47
    근원지는 텍스트 필드였고 화면에 텍스트를 출력합니다
  • 46:47 - 46:50
    버튼 중 하나를 클릭하면
  • 46:50 - 46:53
    예를 들어 Draw left를요
    그럼 사각형을 그려주고요 leftY좌표에서 시작하고요
  • 46:53 - 46:56
    다음 번에 Draw left를 계속 누르면
  • 46:56 - 47:01
    아래쪽으로 아래쪽으로 계속해서 똑같이 사각형을 그려줍니다.
  • 47:01 - 47:03
    두 캔버스다 x좌표는 20이라는 것에 주목해 주세요
  • 47:03 - 47:08
    두 캔버스다 x좌표는 20이라는 것에 주목해 주세요
  • 47:08 - 47:11
    그런데도 서로 다른 장소에 그림이 그려지는 이유는
  • 47:11 - 47:15
    여기에 보이지 않는 경계선이 있기 때문입니다
  • 47:15 - 47:17
    이렇게 해서
  • 47:17 - 47:22
    텍스트, 그래픽, 상호작용자를 모두 포함한 프로그램을 만들어 보았습니다.
    질문 있나요?
  • 47:22 - 47:24
    좋아요, 그럼 수요일날 봅시다
Title:
Lecture 21 | Programming Methodology (Stanford)
Description:

Lecture by Professor Mehran Sahami for the Stanford Computer Science Department (CS106A). Professor Sahami continues lecturing on interactions and pushes it further.

CS106A is an Introduction to the engineering of computer applications emphasizing modern software engineering principles: object-oriented design, decomposition, encapsulation, abstraction, and testing. Uses the Java programming language. Emphasis is on good programming style and the built-in facilities of the Java language.

Complete Playlist for the Course:
http://www.youtube.com/view_play_list?p=84A56BC7F4A1F852

CS106A at Stanford Unversity:
http://www.stanford.edu/class/cs106a/

Stanford Center for Professional Development:
http://scpd.stanford.edu/

Stanford University:
http://www.stanford.edu

Stanford University Channel on YouTube:
http://www.youtube.com/stanford

more » « less
Video Language:
English
Duration:
47:39

Korean subtitles

Incomplete

Revisions