Before-After 이미지 비교 플러그인. 

 

 

Visual Studio 에서 텍스트 편집기 설정을 하는 것은 좀 스트레스 받는 일입니다. 특히 재설치를 했거나 팀 내에 코딩룰이 있다면 좀 더 스트레스를 받죠.

 

그래서 텍스트 편집기의 설정을 공유하는 방법에 대해서 설명하고자 합니다.

 

사실 이건 Visual Stdio 의 환경 설정을 공유하는 방법의 일부라고 봐도 무방합니다. 거의 모든 설정이 포함됩니다.

 

[ 도구 >> 설정 가져오기 및 내보내기 ] 메뉴 아이템을 클릭합니다.

 

 

 

다들 똑똑하신 분들이니 더 이상의 설명은 필요없겠죠? 다이얼로그만 봐도 설명이 다 되어 있네요.

 

[ 다음 ] 버튼을 누르시면 트리뷰가 나오는데 필요한 것만 선택해서 저장/로드하시면 됩니다.

'ETC' 카테고리의 다른 글

before-after plugin test  (0) 2017.07.23
Behavior Tree 개념 및 동작  (6) 2016.06.02
[ 번역 ] 와우 전투 시스템  (0) 2015.11.27
The activity diagram  (0) 2014.10.15
응용 수학에 대해서 참고할 만한 사이트.  (0) 2012.02.22
발음 기호를 제대로 익힐 수 있는 사이트.  (0) 2012.02.22
SyntaxHighlighter test.  (0) 2011.03.01


개요



이 문서는 Beahvior Tree( 이하 BT ) 의 세부적인 구현이나 노드들에서 다루기 위해서 작성된 것이 아니라 전반적인 개념 및 흐름을 정리하기 위해서 작성되었습니다. 그러므로 BT 의 세부적인 동작 방식들에 대해 알고 싶으시다면 가마수트라의 [ Behavior trees for AI: How they work ][ 4 ] 를 읽어 보시기 바랍니다( 하지만 안타깝게도 영문입니다 ).


개념



BT 를 이야기하기 위해서는 유한 상태 기계( Finite State Machines, 이하 FSM )에 대해서 언급하지 않고 넘어 갈 수 없습니다. 


FSM 은 특정 유형의 로직을 제공합니다. 이는 상태( state )와 전이( transition )으로 구성됩니다. 상태는 동시에 실행되는 행동( action )의 집합입니다. 행동의 예를 들면 애니메이션, 사운드, 특정 시간동안 대기 등을 들 수 있습니다. 전이는 조건( condition )을 포함합니다. 전이의 조건이 충족되면, 상태는 다른 상태로 이동하게 됩니다.


게임에서 이러한 FSM 은 애니메이션 상태를 전환하는 데 많이 사용됩니다. 이러한 FSM 의 한 예는 Unity3D 의 메카님 스테이트 머신( Mechanim State Machine )입니다. 이것을 사용하면 한 애니메이션에서 다른 애니메이션으로 전환되는 로직을 쉽게 작성할 수 있습니다[ 5 ].


출처 : [ 4 ]


게다가 비주얼 디버깅( visual debugging )도 매우 쉽습니다. 현재 상태를 보여주기 때문입니다.


출처 : [ 5 ]


하지만 이러한 상태들이 매우 많아지게 되면 노드가 매우 복잡해집니다.  




그렇기 때문에 상태를 계층화( 혹은 그룹화)하는 계층적 유한 상태 기계( Hierarchical Finite State Machines, 이하 HFSM )라는 개념이 등장했습니다[ 3 ].


출처 : [ 3 ]


FSM 은 서로 다른 문맥을 가진 로직을 재사용할 수 있는 방법을 제공하지 않지만, HFSM 은 FSM 들을 그룹화하고 계층화함으로써 특정 문맥을 가진 상태를 재사용할 수 있게 해 줍니다. 그리고 FSM 이 그렇듯이 현재의 문맥( 상위 상태 )을 파악하기도 쉽습니다. 그래서 최근까지 게임 AI 에서 많이 사용되던 방식입니다.


그런데 이 HFSM 도 문제가 있습니다. HFSM 이 어느 정도의 확장성을 가지기는 하지만, ( 하위 ) 상태를 모듈화하는 기능을 제공하지는 않습니다. 예를 들어 같은 상태를 다른 문맥에서 사용할 수는 없습니다. 왜냐하면 특정 상태에서 전이되어야 한다는 조건이 붙어 있기 때문입니다.


좀 더 실용적인 예를 들어 보도록 하겠습니다. 여러분이 "걷기" 상태를 가지고 있다고 합시다. "걷기" 상태는 "전투" 상태의 하위 상태도 될 수 있지만, "추적" 상태의 하위 상태도 될 수 있습니다. 만약 HFSM 을 사용한다면 "전투" 상태에 "걷기" 상태를 추가하고, "추적" 상태에도 "걷기" 상태를 추가해야 합니다. 물론 각 문맥에서의 ( "걷기" 상태로의 ) 전이 조건은 서로 다르겠죠.


그래서 같은 상태를 재작성하지 않고도 다른 목적이나 상황에 따라 상태를 재사용할 수 있도록 하기 위한 목적을 가지고 행동트리( Behavior Tree )라는 것이 생겨났습니다[ 1 ].


BT 는 로직을 캡슐화함으로써 상태의 모듈성을 증가시킵니다. 예를 들면 내포된 상태( 하위 상태 )를 만드는 것이죠. 이는 HFSM 에서도 제공하고 있습니다만, 전이라는 것이 존재하지 않는다는 차이점을 가집니다. 그래서 상태는 그 자체로서 존재할 수 있습니다.


출처 : [ 1 ]


Behaviour Tree 작동 원리



이 부분은 자료구조에 대한 이해가 필요합니다. 일반적으로 BT 를 구현하기 위해서는 스택( Stack )이라는 자료구조를 사용하게 됩니다. 이것은 전형적인 후입선출( Last In First Out ) 방식의 자료구조입니다. 이를 간단하게 도식화하면 다음과 같습니다.


출처 : [ 6 ]


스택에 대해서 언급한 이유는 나중에 언급할 BT 노드들이 동작하는 방식을 이해하는 기반이 되기 때문입니다.


BT 는 태스크( Task ) 집합으로 구성됩니다. FSM 류에서는 행동 집합을 상태라고 하고 상태가 다른 상태로 넘어 갈 수 있는 방향 및 조건을 지정하는 것을 전이라 표현했습니다. 하지만 BT 에서는 모든 것을 노드로 표현합니다.


BT 구현에 따라서 조금씩 다르지만 태스크의 종류는 크게 Composite, Decorator, Condition, Action 으로 나뉩니다. Action 은 단말 태스크로서 FSM 의 행동 집합으로써의 상태에 가깝다고 보시면 됩니다. 보통 태스크와 노드( node )라는 용어를 같은 의미로 사용하는 경우가 많으므로 헷갈리지 않기를 바랍니다.


Action task


Action task 는 실제 행동을 표현하는 단말 노드입니다. 이것은 항상 true false 를 반환하게 되어 있습니다. 일반적으로는 Action.OnStart(), Action.OnUpdate(), Action.OnEnd() 같은 메서드를 가지고 있는데, Action.OnUpdate() 에서 true false 를 반환하면 그 Action 의 작업이 끝납니다. 메서드의 이름은 구현마다 다를 수 있습니다.


스택에 처음 올라갈 때 OnStart() 가 불리고, truefalse 를 반환하지 않으면 계속해서 OnUpdate() 가 불립니다. 그러다가 truefalse 가 반환되면 스택에서 빠지면서 OnEnd() 가 불립니다. 어떤 구현들( UE4, ParadoxNotations 의 NodeCanvas 등 )에서는 EndAction() 과 같은 메서드를 명시적으로 호출해서 Action 을 끝내기도 하고, 어떤 구현들( BehaviorDesigner 등 )에서는 true, falserunning 과 같은 반환값을 기반으로 Action 이 끝났는지 판단하기도 합니다.




Composite task


Composite task 는 우리말로 하면 복합 태스크입니다. 이것은 말 그대로 ( 하나 이상의 ) 여러 개의 자식으로 구성된 태스크입니다. 자주 사용되는 Composite 으로는 Select, Sequence 등이 있습니다. 이러한 Composite 의 핵심 용도는 node 의 flow 를 제어하는 것입니다.


기본적으로 node 의 실행 순서는 위에서 아래로, 왼쪽에서 오른쪽으로입니다.


Select composite자식 노드가 true 를 반환할 때까지 자식 노드들을 실행합니다. 말 그대로 하나를 선택하는 것이죠. 참고로 스샷은 ParadoxNotations 의 NodeCanvas 의 스샷입니다.



위의 Select 를 스택 구조로 도식화하면 다음과 같습니다. 그림이 복잡해지는 것을 방지하기 위해서, OnStart() 에서 바로 EndAction() 을 호출했다고 가정합니다.



다른 것들도 마찬가지로 동작하므로 스택 구조로 도식화하는 것은 여기까지만 하도록 하겠습니다. 


Sequence composite 는 자식 노드가 false 를 반환할 때까지 자식 노드들을 실행합니다. 말 그대로 순차적 실행입니다.



이것들을 잘 조합하면 다양한 로직을 구성할 수 있습니다.



Conditional Aborts


BT 의 단말 노드에 존재하는 Action 이 true 나 false 를 반환하지 않으면 계속해서 그 작업에 머물러 있게 됩니다. 그 Action 의 OnUpdate() 메서드 내부에서 종료 조건을 판단할 수 있으면 좋겠지만 외부에서 강제적으로 그 Action 의 실행을 중단시키고 싶을 수 있습니다. 


예를 들어 "추적" 이라는 Action 은 일반적으로 내부에서 추적이 완료되었는지 여부를 판단하고 있을 것입니다. 예외적인 조건 판단까지 그 Action 에 넣어 버리면 너무 복잡해지고, 다른 Action 에 대한 종속성을 가지게 될 것입니다. 이럴 경우에 "추적" Action 을 취소시킬 수 있는 방법이 있다면 좋을 것입니다. 그런 방법을 조건부 취소( Conditional Aborts )라 부릅니다. 어떤 구현에서는 평가를 재활성화한다( Reactive Evaluation )고 합니다.


조건부 취소는 실행 흐름에 영향을 주게 되므로 Composite 에 기능이 내장되어 있습니다. 어떤 변수를 계속 감시하고 있다가 변수의 값이 바뀌게 되면 지금의 실행 흐름을 취소시키고 자신의 노드로부터 재평가를 하는 것입니다. 


Conditional Aborts 는 보통 Self, Lower Priority, Both 로 이루어집니다. Self 는 자신의 하위에 있는 태스크를 취소시키는 것이고, Lower Priority 는 자신의 오른쪽에 있는 이웃 노드의 흐름을 취소시키는 것입니다. 그리고 Both 는 Self + Lower Priority 입니다. 여기에서 Lower Priority 라는 의미를 이해하기 힘든 분이 있을 수 있습니다. Lower 라는 이름이 붙은 이유는 BT 의 실행 흐름이 왼쪽에서 오른쪽으로 이어지기 때문입니다.


간단한 예를 들어 보도록 하겠습니다. 일단 NodeCanvas 의 경우에는 Composite 에 Dynamic 이라는 속성이 있습니다. 이것은 Conditional aborts on Self 를 의미합니다. UE4 나 BehaviorDesigner 는 Self, Lower Priority, Both 를 모두 가지고 있습니다. 어쨌든 계속해서 실행되는 어떤 Action 이 있다고 합시다. 아래 BT 에서는 "B" Action 을 실행한 후에 "Run Forever" 라는 Action 으로 제어가 넘어 갔기 때문에, "B" Action 은 앞으로 절대로 평가되지 않습니다.



그런데 특정 조건이 만족되면 다시 Sequece Composite 를 평가하고 싶다면 어떻게 해야 할까요? 이럴 때 Sequencer 노드를 dynamic 으로 변경하고, 하위에 Condition 노드를 추가해 Conditional Aborts 상황을 만들 수 있습니다. 형태는 다음과 같습니다.



이제 Cancel 이라는 변수에 false 를 할당하면, Sequencer 노드가 이를 감시하고 있다가 "Run Forever" Action 을 취소하고 다시 자신의 노드를 평가합니다. 참고로 취소될 때는 "Run Forever" 의 OnEnd() 가 호출됩니다.



여기에서 "Sequencer 가 첫 번째 노드에서 false 를 반환해서 멈춰버리네?" 라는 의문을 가지는 분이 계실 겁니다. 이런 사태에 대비해서 모든 Action.OnEnd() 안에서 Cancel = true 로 만들어 주는 방법이 있고, Condition 앞에서 true 로 만들어 줄 수도 있습니다. 어떤 방법을 선택하느냐는 취향의 문제입니다. 심지어는 Sequencer.OnUpdate() 에서 true 로 만들어 줘도 되겠죠.



그냥 순차적으로 실행되는 것이라고 생각하면 의미가 모호하지만, 이것의 실행 문맥( 스택이 rewind 된 것임 )을 잘 생각하면 문제가 없습니다.


참고로 NodeCanvas 같은 경우에는 Dynamic Composite 을 계층적으로 사용하면 Both 와 같은 Conditional Aborts 를 처리하는 것도 가능합니다. 그냥 Composite 에서 세 종류를 모두 설정할 수 있었으면 좋았겠지만 그 부분이 아쉽습니다.


Decoration task


Decoration task 는 조건을 의미합니다. Decoration 은 하나의 자식만을 가질 수 있는데, 조건을 만족하면 자식을 실행하고, 조건을 만족하지 못하면 false 를 반환합니다. Decoration 이 지정하는 조건을 만족했을 경우의 반환 결과는 자식의 반환 결과에 의존합니다. 자주 사용하는 Decoration 에는 Probability, TimeOut, CheckEvent 등이 있습니다. 


예를 들어 "B" Action 과 "C" Action 의 실행 확률을 결정하고 싶다고 합시다. 그러면 Probability task 를 사용해 다음과 같이 할 수 있습니다. 



참고



[ 1 ] Understanding Behavior Trees.

[ 2 ] On Finite State Machines and Reusablility.

[ 3 ] The Gist of Hierarchical FSM.

[ 5 ] 스테이트 머신 기초.

[ 6 ] Stack Data Structures.

못 그려도 그냥 올림. 하다 보면 늘겠지...



'ETC > Digital Painting' 카테고리의 다른 글

물고기2  (0) 2015.10.15
물고기  (0) 2015.10.14
인간 뼈대  (0) 2014.09.09
고양이 뼈대와 몸  (0) 2014.09.03
고양이 근육 연습  (0) 2014.08.31
고양이 뼈 연습 및 사이트 링크  (0) 2014.08.26
고양이과 골격 연습 측면  (0) 2014.08.24
얼굴 일부  (0) 2014.04.14
프로도????  (0) 2014.04.05
사람연습  (0) 2014.03.18

다른 게임들의 전투 시스템을 어떻게 구현하는지 궁금해서 제가 좋아했던 와우의 전투 시스템에 대해서 번역해 보았습니다. 아래 첨부된 PDF 파일을 보시면 됩니다.



WOW_Battale.pdf



목차


1. 전투 이벤트 5

    1.1. 일반 전투 이벤트 5

        1.1.1. 평타( Hit ) 5

        1.1.2. 치명타( Critical Hit ) 5

    1.2. 난투 관련( melee-specific ) 전투 이벤트 5

        1.2.1. 실패( Miss ) 5

        1.2.2. 회피( Dodge ) 6

        1.2.3. 무기막기( Parry ) 6

        1.2.4. 방패막기( Block ) 6

    1.3. 주문 관련 전투 이벤트 7

        1.3.1. 저항( Resist ) 7

    1.4. NPC 관련 전투 이벤트 7

        1.4.1. 강타( Crushing Blow ) 7

        1.4.2. 빗맞음( Glancing Blow ) 7


2. 히트 테이블 8

    2.1. 히트 테이블 이해하기: 기초 8

    2.2. 한-주사위 혹은 두-주사위? 치명타 9

    2.3. 결과 배제하기 11

    2.4. 역학 세부사항 12

        2.4.1. 공격 순서 12

    2.5. 특수 규칙 12

        2.5.1. 몹 상호작용 12

        2.5.2. 후방 공격 12

        2.5.3. 사냥꾼과 자동사격 12


3. 데미지 12

    3.1. 물리 데미지 12

    3.2. 주문 데미지 및 힐링 13


4. 위협( Threat ) 14

    4.1. 증오 리스트 14

    4.2. 위협 생성 15

    4.3. 타깃 변경 16

        4.3.1. 끈끈한( Sticky ) 어그로 16

        4.3.2. 도발( Taunting ) 17

        4.3.3. 어그로 상실 17

    4.4. 위협 조절하기 17

    4.5. 위협과 탱킹 19

    4.6. 위협과 치유 19

    4.7. 위협과 DPS 19

    4.8. 비표준 증오 구조. 19


5. DPS 20

    5.1. 무기에서 DPS 20

    5.2. 캐릭터에 대한 DPS 21

    5.3. 캐릭터 특성으로서의 DPS 21

    5.4. 역할로서의 DPS 21

    5.5. 동사로서의 DPS 21


6. 능력치( Attributes ) 21



너무 베끼려고 하지 말고 느낌( 양감 )을 살리려고 노력하라고 해서 다시 시도해 봄.

 

여전히 맘에 안 들지만 어제보다는 훨씬 빠른 시간에 더 나은 결과가 나온듯...

 

 

 

'ETC > Digital Painting' 카테고리의 다른 글

미사일  (0) 2016.04.07
물고기  (0) 2015.10.14
인간 뼈대  (0) 2014.09.09
고양이 뼈대와 몸  (0) 2014.09.03
고양이 근육 연습  (0) 2014.08.31
고양이 뼈 연습 및 사이트 링크  (0) 2014.08.26
고양이과 골격 연습 측면  (0) 2014.08.24
얼굴 일부  (0) 2014.04.14
프로도????  (0) 2014.04.05
사람연습  (0) 2014.03.18

사진 보고 그려 봤는데, 그리드를 써야 대충이라도 비율을 맞출 수 있다. 눈이 삐꾸임 ... 사진은 날렵한 깡패 고기같은데, 내가 그린건 뚱보임.


색감은 정말 맞추기 어려운 듯. 컬러 픽커를 안 쓰고 그냥 대충 맞춰 봤는데, 절대 안 맞음. 연습을 많이 안 해 봐서 그럴 것이라 생각하기는 하지만... 눈이 맛이 간 게 아닐까 의심이 들기도... 


여러 색이 섞여 있는 팔레트에서 같은 색을 고르는 게 참 어려운 것 같다.


디테일 표현은 어떻게 하는 건지 잘 모르겠다. 빡세게 그리든가, 적절한 브러쉬를 쓰든가 해야 할 듯.




'ETC > Digital Painting' 카테고리의 다른 글

미사일  (0) 2016.04.07
물고기2  (0) 2015.10.15
인간 뼈대  (0) 2014.09.09
고양이 뼈대와 몸  (0) 2014.09.03
고양이 근육 연습  (0) 2014.08.31
고양이 뼈 연습 및 사이트 링크  (0) 2014.08.26
고양이과 골격 연습 측면  (0) 2014.08.24
얼굴 일부  (0) 2014.04.14
프로도????  (0) 2014.04.05
사람연습  (0) 2014.03.18

UML basics Part II: The activity diagram



원문링크 : https://www.ibm.com/developerworks/rational/library/content/RationalEdge/sep03/f_umlbasics_db.pdf


주의 : 허락받고 번역한 것이 아니므로 언제든 내려갈 수 있습니다.

주의 : 번역이 개판이므로 이상하면 원문을 참조하십시오.




2003 년에, Rational Edge 는 IBM 글로벌 서비스의 도날드 벨( Donald Bell ) 이 작성한 새로운 아티클 시리즈를 소개했는데, 그것은 UML Basics 라고 합니다. 이 시리즈의 목적은 독자들이 UML 의 대부분을 구성하는 주요 다이어그램에 익숙해지도록 돕는 것입니다. 파트 1 은 이 다이어그램들에 대한 일반적인 개관을 제공했습니다; 이번 달에는, 활동( activity ) 다이어글매에 대한 세부 사항에 대해서 다루는데, 이 다이어그램은 완전한 UML v1.4 표기 집합을 포함하고 있습니다.



활동 다이어그램의 목적



활동 다이어그램의 목적은 큰 활동의 일부인 액션들의 절차적 흐름을 모델링하는 데 있습니다. 유스 케이스가 제출된 프로젝트에서, 활동 다이어그램들은 특정 유스 케이스를 좀 더 세부적인 레벨에서 모델링할 수 있습니다. 그러나 활동 다이어그램들은, 콘서트 티킷을 구입하거나 단과 수업을 등록하는 것과 같은, 비즈니스-레벨 기능들을 모델링하기 위해 유스 케이스들과는 독립적으로 사용될 수 있습니다. 활동 다이어그램들은, 티킷 예약 데이터 마트가 공동 세일즈 시스템의 데이터 웨어하우스를 덧붙이는 방식과 같은, 시스템-레벨 기능들을 모델링하는데 사용될 수도 있습니다.


그것은 절차적인 흐름을 모델링하기 때문에, 활동 다이어그램은 실행을 위한 액션 시퀀스와 그러한 액션들을 유발하거나 보호하는 상태들에 초점을 맞춥니다. 또한 활동 다이어그램은 활동의 내부 액션들에만 초점을 맞춥니다. 그것들의 처리 흐름에서 활동을 호출하는 액션들이나 특정 이벤트와 관련해 활동을 유발하는 액션들에는 관심을 두지 않습니다( 4월 13일 12:30 이며, 그룹의 섬머 투어를 위한 그린 데이 티킷들을 이제 판매한다 ).


UML 시퀀스 다이어그램들이 활동 다이어그램과 동일한 정보를 보여 주기는 하지만, 나는 개인적으로 활동 다이어그램들이 비즈니스-레벨 기능들을 모델링하는 것에 있어 최고라는 것을 발견했습니다. 왜냐하면, 활동 다이어그램은 활동에 있어서의 모든 잠재적인 시퀀스 흐름들을 보여 주기 때문입니다. 반면에 시퀀스 다이어그램은 보통 활동에 대한 하나의 흐름만을 보여 줍니다. 또한, 비즈니스 매니저와 비즈니스 인사 과정( process personnel )은 시퀀스 다이어그램들 보다는 활동 다이어그램을 선호하는 것처럼 보입니다 -- 활동 다이어그램은 보기에 덜 "기술적"이며, 그래서 비즈니스를 하는 사람들에게 겁을 덜 줍니다.게다가, 비즈니스 매니저들은 흐름 다이어그램들을 보는 것에 익숙해서, 활동 다이어그램의 "외형"에 친숙합니다.



표기( notation )



활동 다이어그램의 표기는 상태차트 다이어그램과 매우 유사합니다. 사실, UML 명세에 따르면, 활동 다이어그램은 상태차트 다이어그램의 변종입니다. 그래서 만약 당신이 상태차트 다이어그램에 익숙하다면, 활동 다이어그램 표기법을 이해하는데 한 다리 걸치게 된 것이며, 아래에서의 많은 논의들이 당신에게는 리뷰가 될 것입니다.



기본



먼저, 활동 다이어그램에서 액션 요소를 살펴 봅시다. 이것의 공식 UML 이름은 액션 상태( action state )입니다. 내 생각에는 사람들이 그것을 액션 상태라고 부르는 경우는 거의 없는 것 같습니다; 보통 액션이나 활동이라고 부릅니다. 이 기사에서, 나는 그것을 항상 액션이라고 부르도록 하겠습니다. 그리고 활동이라는 개념은 활동 다이어그램에 의해서 모델링되고 있는 전체 작업을 부를 때만 사용할 것입니다. 이러한 구분은 내 설명을 더 이해하기 쉽게 만들어 줄 것입니다.


활동 다이어그램에서의 액션은 "캡슐" 모양에 의해 표시됩니다 -- 왼쪽과 오른쪽 끝에 반쪽 원들을 가지고 있는 사각형 개체입니다( Figure 1 참조 ). 내부의 텍스트는 액션을 가리킵니다( 예를 들어 "사용자가 티킷 사무소에 전화를 겁니다" 혹은 "등록 사무소가 문을 엽니다" ).


Figure 1: 활동 다이어그램의 일부인 샘플 액션.


활동 다이어그램들은 액션의 시퀀스를 보여 주므로, 그것들은 반드시 시퀀스의 시작 지점을 표시해야 합니다. 활동 다이어그램 시작 지점의 공식 UML 이름은 초기 상태( initial state )입니다. 그리고 그것은 액션 시퀀스를 읽기 시작할 위치입니다. 초기 상태는 채워진 원으로 그려지는데, 활동의 액션 시퀀스에서 처음 액션과 연결하는 전이 라인( transition line, 화살표 )를 가지고 있습니다. Figure 2 는 활동 다이어그램의 초기 상태가 어떻게 생겼는지 보여 줍니다. UML 명세는 활동 다이어그램에서 초기 상태의 위치를 지정하지는 않습니다만, 보통은 당신의 다이어그램의 좌상단 코너에 있는 첫 번째 액션에 배치되는 것이 가장 쉽습니다.


Figure 2: 초기 상태는 활동 다이어그램의 액션 시퀀스를 위한 시작 지점을 명확하게 보여 줍니다.


활동 다이어그램에는 하나만의 초기 상태만 존재할 수 있으며, 초기 상태와 연결되는 하나만의 전이 라인만 존재할 수 있다는 것을 기억하는 것이 중요합니다. 활동 다이어그램이 하나만의 초기 상태를 가질 수 있다는 것이 명확해 보임에도 불구하고, 애매한 상황들이 있습니다 -- 이름하여, 비동기 액션 시퀀스의 시작. 이 상황들은 활동 다이어그램에서 새로운 초기 상태가 표시되어야 함을 암시할 수도 있습니다. Figure 3 은 잘못된 활동 다이어그램의 예를 보여 줍니다. 왜냐하면 그것의 초기 상태가 두 개의 액션들을 가리키는 두 개의 전이 라인을 가지기 때문입니다.


Figure 3: 활동 다이어그램에서 초기 상태의 잘못된 렌더링. 초기 상태는 단지 하나의 액션만을 지목할 수 있습니다.


화살표가 가리키는 방향과 함께, 활동 다이어그램의 전이 라인들은 모델링된 활동에서의 액션의 연속된 흐름을 보여 줍니다. 화살표는 항상 활동 다이어그램 시퀀스에서의 다음 액션을 가리킵니다. Figure 4 는 완전한 활동 다이어그램을 보여 주는데, 고객이 콘서트 티킷을 예약하는 방법을 모델링합니다.


Figure 4: 이해하기 쉬운 액션 시퀀스를 만드는 완전한 활동 다이어그램.


Figure 4 의 샘플 활동 다이어그램은 "콘서트 티킷 예약하기" 활동을 기술하는데, 다음과 같은 순서로 액션을 실행합니다:

  1. 고객이 티킷 사무소에 전화를 겁니다.
  2. 티킷 판매 대리인( Ticket rep )은 그 사람이 어떤 이벤트를 위한 티킷을 원하는지 묻습니다.
  3. 고객이 대리인에게 선택한 이벤트를 말해 줍니다.
  4. 대리인이 이용 가능한 좌석과 가격을 고객에게 말해 줍니다.
  5. 고객이 선택한 좌석을 대리인에게 말해 줍니다.
  6. 대리인이 좌석을 예약합니다.
  7. 대리인이 신용 카드와 청구 주소에 대해 묻습니다.
  8. 고객이 요구된 정보를 제공합니다.
  9. 대리인이 신용 카드를 결제합니다.
  10. 대리인이 티킷을 우편으로 보냅니다.


위의 액션 순서는 다이어그램에서 명확합니다. 왜냐하면 다이어그램은 초기 상태( 시작 지점 )를 보여 주고, 그 지점으로 부터 사람들은 전이 라인을 따라서 그것들이 연결된 활동들의 액션을 따라갈 수 있기 때문입니다.


활동의 흐름은 시퀀스에서 마지막 액션의 전이 라인이 "최종 상태" 심볼과 연결될 때 끝납니다. 그 심불은 과녁모양입니다( 채워진 원을 둘러싼 원 ). Figure 4 에서 보이듯이, "Ticket Rep Mails Tickets" 액션은 최종 상태 심볼과 연결되며, 그것은 활동의 액션 시퀀스가 끝에 도달했음을 지시합니다. 모든 활동 다이어그램은 적어도 하나의 최종 상태 심볼을 가집니다; 그렇지 않으면, 독자들은 어디에서 액션 시퀀스가 끝나는지 불명확하게 느낄 것이며, 혹은 활동 다이어그램이 여전히 작동중이라고 간주하게 될 것입니다.


활동 다이어그램이 여러 개의 최종 상태를 가지는 것이 가능합니다. 활동 다이어그램에서 단 하나만 존재해야 하는 초기 상태 심볼과는 다르게, 최종 상태 심볼은 로직 내의 많은 가지들 중의 하나의 끝을 표현할 수 있습니다 -- 다시 말해, 활동 다이어그램은 여러 가지 방식으로 끝날 수 있습니다.



기본의 너머에



우리는 활동 다이어그램의 기본 표현 요소들에 대해 다뤄왔지만, 이 유형의 다이어그램에 배치될 수 있는 더 많은 표현 요소들이 여전히 존재합니다. Figure 4 의 다이어그램이 기술적으로는 완전하지만, Figure 4 에서 모델링된 활동은 매우 단순합니다. 보통, 실제 소프트웨어 개발 프로젝트에서 모델링되는 활동들은 어떤 액션들을 취할지를 제어하는 결정 지점( decision point )들을 포함합니다. 그리고 가끔은 활동들이 병행적인 액션들을 가집니다.



결정 지점( decision points )


일반적으로, 결정은 활동 전반에서 필요한데, 특정한 이전 액션의 출력에 의존합니다. 그러한 경우에 활동 다이어그램을 생성하면서, 당신은 두 개 이상의 서로 다른 액션 시퀀스를 모델링할 필요가 있을 것입니다. 예를 들어, 중국 배달 음심을 주문할 때, 나는 중국 음식 배달원에게 전화를 겁니다. 그리고 내 전화 번호를 줍니다. 그리고 내가 이전에 음식을 주문한 적이 있다면 그의 컴퓨터가 자동적으로 내 주소를 출력해 줄 것입니다. 하지만 내가 처음 전화를 건 새로운 고객이라면, 그는 내 주문을 받기 전에 내 주소를 획득해야 할 것입니다.


UML 명세는 결정을 모델링하기 위해, 아래와 같이 두 가지 방식을 제공합니다.


첫 번째 방식은 액션에서 나오는 단일 전이 라인을 표시하고, 그것을 결정 지점과 연결하는 것입니다. UML 명세는 결정 지점을 결정( decision )이라고 부릅니다. 그리고 그것은 활동 다이어그램에서 다이아몬드 모양으로 그려집니다. 결정은 적어도 두개의 서로 다른 출력을 가질 것이므로, 결정 심볼은 서로 다른 액션들과 연결되는 다중 전이 라인들을 가질 것입니다. Figure 5 는 결정을 포함하는 샘플 활동 다이어그램의 일부를 보여 줍니다.


Figure 5: 결정 지점은 액션 시퀀스 내에서 생성되어야만 하는 선택을 모델링합니다.


Figure 5 에서 보이듯이, 결정 지점에 포함된 각 전이 라인은 반드시 "가드 조건( guard condition )"을 지시하기 위해서 위와 같은 텍스트에 의해서 레이블링되어야만 합니다. 이는 보통 guards 라고 발음됩니다.


가드 조건 텍스트는 항상 대괄호 내에 배치됩니다 -- 예를 들어 [ 가드 조건 텍스트 ] 입니다. 가드 조건은 전이 조건이 다음 액션으로 언제 이동할 지를 명시적으로 말해 줍니다. Figure 5 의 결정 지점에 따르면, 바텐더( 사용자 )는 단지 고객이 술을 주문할 때 "사용자가 적어도 21 살인지 확인한다" 만을 필요로 합니다. 만약 고객 주문이 다른 종류의 음료를 주문하면( "else" 조건 ), 바텐더는 그냥 고객에게 드링크를 제공하기만 하면 됩니다. 활동 다이어그램에서 [else] 가드는 보통 "만약 다른 가드된 전이 라인들이 실제 조건과 일치하는 것이 없을 때" 를 의미하기 위해서 사용되며, [else] 전이 라인을 따라 가게 됩니다.



병합 지점( merge points )


Figure 6 의 "고객 나이 >= 21" 에서 볼 수 있듯이, 가끔은 한 조건 경로로부터의 절차적 흐름이 다른 조건 경로로 다시 연결됩니다. 이러한 경우에, 우리는 두 개 이상의 액션 경로들을 다중 경로들이 그것을 가리킬 때 사용했던 것과 동일한 다이아몬드 아이콘을 사용해 연결합니다. 그렇지만 그것으로 부터 나오는 전이 라인은 하나 뿐입니다. 이는 결정 지점을 가리킨다기 보다는, 병합( merge )을 가리킵니다.


Figure 6 은 Figure 5 와 같은 결정을 보여 주지만, Figure 6 은 그 활동 다이어그램을 확장합니다. 고객의 나이에 대한 검사를 수행하는 것은 사용자를 두 번째 결정으로 유도합니다; 만약 고객이 21 살 보다 어리다면, 바텐더는 고객에게 다른 비알콜 음료를 주문하라고 말해야만 하며, 그것은 "Customer Orders Drink" 액션으로 시퀀스를 되돌립니다. 그러나 만약 고객이 21 살 이상이라면, 우리 액션 시퀀스는 비알콜 드링크를 주문했을 때 바텐더가 따라야 하는 것과 동일한 액션을 취하게 됩니다: "Get Drink For Customer".


Figure 6: 부분 활동 다이어그램, 

두 개의 결정 지점( "Drink is alcoholic" 과 "Customer's age < 21" )과 하나의 병합 지점( "else" 와 "Customer's age >= 21" )을 보여 줍니다.



대안적인 접근


결정을 모델링하는 두 번째 접근법은 Figure 7 에서처럼 액션의 결과로 다중의 전이 라인을 가지는 것입니다. 만약 이 기법이 사용되면, 액션으로부터 나오는 전이 라인은 첫 번째 접근법의 결정처럼( 예를 들어 다이아몬드 심볼 ) 반드시 가드 레이블을 그 위에 가져야만 합니다. 결정 심볼에 적용되는 모든 규칙이 액션 외부에서 모델링되는 결정들에 적용됩니다. 갱니적으로, 나는 이 접근법을 추천하지 않습니다. 왜냐하면 나는 결정에 대한 가시적인 대기열을 선호하기 때문입니다. 그렇기는 하지만 UML 1.4 명세는 Figure 7 에서 볼 수 있듯이 이 접근법을 허용하며, 완결성을 높이기 위해서 여기에서 그것을 언급했습니다.


Figure 7: 나는 이 접근법을 선호하지는 않지만, UML 1.4 명세는 가드 조건들을 사용해 결정을 액션처럼 모델링하는 것을 허용합니다.


만약 당신이 이 접근법을 사용한다면, 반드시 다중 액션 시퀀스를 단일 시퀀스로 병합해야만 합니다. 이를 위해서, 당신은 특정 액션 시퀀스 내의 마지막 전이 라인을 시퀀스가 다시 시작되는 곳에 연결합니다. Figure 7 에서, "Tell Customer to order a non-alcoholic drink" 로부터의 전이라인이 "Customer orders drink" 로 되돌아 가는 것을 보여 줍니다.


Figure 8: 결정을 모델링하는 두 번째 접근법.



비동기 액션( asynchronous actions )들을 위한 동기화 상태( synch states )


활동을 모델링할 때, 가끔 병행적으로나 비동기적으로 수행될 수 있는 액션 시퀀스들을 보여 줘야 할 필요가 있습니다. 특별한 표기 요소가 병행 액션 시퀀스들을 보여 줄 수 있도록 합니다. 공식적인 이름으로는 동기화 상태( synch states )인데, 그것이 활동 흐름의 동기화 상태를 가리키기 때문입니다. 동기화 상태는 실행 스레드의 분기( forking )와 결합( joining )을 허용합니다.명확함을 위해 언급하자면, 액션을 두 개 이상의 스레드로 분기시키는 동기화 상태는 ( 비동기 액션들인 ) 비동기화( de-synchronizing )를 표현하며, 액션들을 다시 결합하는 동기화 상태는 동기화된 흐름으로의 복귀를 표현합니다. 동기화 상태는 굵은 채워진 라인으로 그려지는데, 전이 라인이 ( 보통 ) 그것의 왼쪽으로 들어 오며, ( 보통 ) 오른쪽으로 나갑니다. 액션 시퀀스를 다중 스레드로 분기시키는 동기화 상태를 그리기 위해서는, 먼저 병행 시퀀스에 앞서 액션으로부터의 전이 라인을 동기화 상태에 연결합니다. 그리고 나서 두 개의 전이 라인을 동기화 상태로부터 뽑아서, 각각을 자신의 액션에 연결합니다. Figure 9 에서 실행의 분기를 보여주는 활동 다이어그램의 일부분입니다.


Figure 9: 굵은 채워진 라인은 동기화 상태를 가리키는데,

두 개 이상의 액션 시퀀스가 병행적으로 처리되는 것을 허용합니다.


Figure 9 에서 보여준 예제에서, "Receive Order" 액션이 완료된 후에, 두 개의 스레드들이 병행적으로 수행됩니다. 이는 시스템이 "Verify Ordered Products Are In Stock" 액션과 "Verify Customer Has Available Credit" 액션을 동시에 처리할 수 있도록 해 줍니다.


실행을 다중 스레드로 분기시킬 때, 보통 나중의 처리를 위해서 특정 지점에서 그것들을 다시 합쳐야 합니다. 그러므로, 동기화 상태 요소는 다중 스레드들이 단일 스레드로 결합되는 것을 표현하는데 사용되기도 합니다. Figure 10 은 두 개의 스레드가 하나의 스레드로 결합되는 활동 다이어그램의 일부분을 보여 줍니다.


Figure 10: 병행 액션 시퀀스가 종료될 때, 동기화 상태( 굵은 라인 )이 사용되는데,

이는 다중 스레드가 다시 단일 스레드로 결합되는 것을 지시합니다.


Figure 10 에서, "Verify Ordered Products Are In Stock" 액션과 "Verify Customer Has Available Credit" 액션은 Figure 9 에서 보여 준 것이며, 이는 처리가 완료된 것입니다. 그리고 "Accept Order" 액션이 처리됩니다. 단일 전이 라인이 동기화 상태로부터 나오는 것은 이제 단지 하나만의 실행 스레드가 존재한다는 것을 의미한다는 것을 기억하십시오.


동기화 상태는 활동에서의 전체적인 액션 실행에서 동기화 지점으로서 사용될 수도 있습니다. 이 경우에, 그것은 개별 스레드들이 그 이후의 실행이 진행되기 이전에 강제로 결합되는 방식을 모델링합니다. Figure 11 은 동기화 지점으로서 동기화 상태를 사용하는 활동 다이어그램의 일부분을 보여 줍니다.


Figure 11: 동기화 지점으로서 동기화 상태를 사용함.


추상적이기는 하지만, 나는 Figure 11 의 다이어그램은 동기화 상태가 동기화 지점으로 사용되는 방식을 쉽게 이해하게 해 주는 방식을 제공한다고 생각합니다. 이를 이해하기 위해서, 활동 시퀀스를 여기에서 명확하게 해 봅시다. 활동은 하나의 스레드에서 모든 액션들을 시작합니다. 그리고 "Main Thread Action XXX" 액션이 실행될 때, 활동은 세 개의 스레드로 분리되며 병행적으로 실행됩니다. 첫 번째 스레드에서, "Thread 1 Action 1" 이 실행되고, 그리고 나서 "Thread 1 Action 2" 이 실행됩니다. 이 첫 번째 스레드가 실행되는 것과 동시에, 두 번째 스레드와 세번째 스레드가 실행됩니다 -- 각각 "Thread 2 Action 1" 과 "Thread 3 Action 1" 입니다. 두 번째 동기화 상태를 가짐으로써( Figure 11 의 오른쪽에 있는 것, 역주 : 아래쪽인듯 ), 우리는 더 진행하기 전에 "Thread 1 Action 2", "Thread 2 Action 1", "Thread 3 Action 1" 이 완료될 때까지 기다립니다. 모든 이전 액션들이 수행되면, 오른쪽 동기화 상태는 이전 세 스레드들을 동기화합니다. 그리고 나서 두 개의 스레드가 분기되고, 이 스레드들에서 두 액션들이 병행적으로 실행됩니다.


이제, 이 예제에서 가장 중요한 부분이 무엇인지가 나옵니다. 다중 스레드가 실행중일 때, 한 스레드의 액션들은 병행 스레드들에서 실행중인 액션들에 영향을 주어서는 안 됩니다. Figure 11 에서, "Thread 1 Action 1" 액션은 아마도 빨리 수행될 것이고, "Thread 1 Action 2" 액션은 "Thread 2 Action 1" 이 완료되기 전에 처리를 시작할 것입니다. 다른 병행 스레드들을 위해 스레드들을 대기하도록 만드는 유일한 것은 동기화 상태이며, Figure 11 에서 보여 준 것처럼 배치되어 있습니다.


위의 모든 예제에서, 동기화 상태들은 굵은 수직 라인으로 그려집니다; 하지만 UML 명세는 이 라인들이 한 방향이나 다른 방향을 향해야 한다고 요구하지는 않습니다. 동기화 상태는 수평 굵은 라인이거나 심지어는 대각선의 굵은 라인일 수도 있습니다. 그러나 UML 다이어그램들은 가능한 한 쉽게 정보를 교환하기 위한 수단입니다; 그래서 사람들은 보통 수직 라인이나 수평 라인으로 동기화 상태를 그립니다; 단지 복잡한 상황일 때만( 예를 들어 화이트보드나 종이의 공간이 부족할 때 ) 동기화 상태가 이상한 각도로 그려질 수 있습니다.



스윔레인( Swimlanes )


활동 다이어그램에서 실제로 액션들을 실행하는 개체( 사람, 조직, 혹은 다른 책임 엔터티 ) 사이에서 활동의 절차적 제어 흐름을 모델링하는 것이 유용합니다. 이를 위해서, 당신은 스윔레인( swimlane )을 활동 다이어그램에 추가할 수 있습니다( 스윔레인은 수영 대회에서 둘 이상의 경쟁자들 사이에 있는 직선 경계와 닮았기 때문에 이름붙여졌습니다 ).


활동 다이어그램에 스윔레인을 넣기 위해서, 수직 열( column )을 사용합니다. 하나 이상의 액션을 실행하는 각 개체들은, 자신의 이름을 그 열의 최상위에 할당합니다. 그리고 나서 개체와 관련이 있는 액션들을 그 개체의 스윔레인에 배치합니다. Figure 12 는 액션들을 수행하는 두 개의 개체들을 보여 줍니다( Band Manager 와 Reporting Tool ). Band Manager 개체는 "Selects the View Sales For My Band Report" 액션을 실행하며, Reporting Tool 개체는 "Retrieve Bands the Band Manager Manages" 액션을 실행합니다. 비록 스윔레인이 활동 다이어그램의 명료성을 증진시켜주기는 하지만( 왜냐하면 모든 활동들이 자신의 실행 개체의 스윔레인에 배치되기 때문에 ), 이전에 언급한 활동 다이어그램을 관리하기 위한 모든 규칙들이 여전히 적용된다는 것을 기억하는 것이 중요합니다. 다시 말해, 당신은 스윔레인이 사용되지 않은 것처럼 활동 다이어그램을 읽으면 됩니다.


Figure 12: 두 개의 스윔레인은 Band Manager 개체의 액션을 Reporting Tool 개체의 액션과 구분합니다.



진보된 표기 요소들



지금까지 살펴 봤듯이, 액션들은 보통 개체에 의해 실행됩니다. 하지만 다른 액션에 대한 입력인 개체의 출력이 액션일 수 있습니다. UML 명세는 이 개체 입력/출력이 활동 다이어그램에서 모델링되도록 절대적인 요구를 하지는 않습니다만, 가끔은 그렇게 하는 것이 스윔레인을 다이어그램에서 제공하는 것이 유용한 것과 같은 이유로 유용합니다. 이러한 개체 흐름을 모델링하기 위해서, UML 은 액션-개체 흐름 관계( action-object flow relationship )라는 표기를 가지고 있는데, 이것은 두 가지 형태의 심볼을 포함합니다 -- 오브젝트 플로우( object flow )상태 개체( object in state ).



오브젝트 플로우( Object flow )


오브젝트 플로우는 전이 라인과 동일한 것입니다만, 채워진 선이 아니라 점선으로 표시됩니다. 오브젝트 플로우 라인은 상태 개체( object in state ) 심볼에 연결됩니다. 그리고 다른 오브젝트 플로우 라인은 상태 개체를 다음 액션과 연결합니다. Figure 13 은 액션-개체 흐름 관계를 보여 줍니다.


Figure 13: 액션-개체 흐름 관계


Figure 13 에서, 두 액션 사이의 전이 라인 대신에, 액션-개체 흐름 관계 심볼을 볼 수 있습니다. 이는 두 액션 사이에서 액션-개체 흐름 관계가 다른 액션으로의 전이를 내포하므로, 전이 라인들이 중복되는 것으로 고려되기 때문입니다( 역주 : 액션-개체 흐름 관계가 전이 라인을 대체하므로, 액션 사이에 전이 라인이 필요하지 않다는 의미. ).


상태 개체( Object in state )


상태 개체( Object in state ) 심볼은 Figure 13 에서 사각형으로 표현됩니다. 상태 개체 심볼의 첫 번째 부분은 밑줄친 텍스트입니다. 사각형에서 밑줄친 텍스트는 개체의 클래스 이름입니다 -- 우리 예제에서는 "Order" -- 그리고 이 클래스는 모델링된 시스템의 클래스 다이어그램에서 찾아볼 수 있을 것입니다. 상태 개체의 두 번째 부분은 괄호 내부의 텍스트인데, 이는 오브젝트의 상태 이름입니다. 오브젝트의 상태를 포함하는 것은 선택적입니다만, 액션이 개체의 상태를 변경한다면 오브젝트 상태를 포함시키는 것을 추천합니다. Figure 14 는 다중의 액션-개체 흐름 관계들을 가진 완전한 활동 다이어그램을 보여 줍니다.


Figure 14: "Place Order" 액션은 Order 개체를 "Placed" 상태로 만듭니다;

그리고 나서 "Verify Ordered Products Are In Stock" 액션은 Order 개체를 "Accepted" 상태로 옮깁니다.


액션-개체 흐름 관계들을 포함하는 것은 활동 다이어그램을 읽는 방식을 변경시키지 않습니다; 이것은 그냥 부가적인 정보를 제공합니다. Figure 14 에서 "Place Order" 액션은 Order 개체에 "Placed" 상태를 설정합니다; 나중에 "Verify Ordered Products Are In Stock" 액션은 Order 오브젝트를 "Accepted" 상태로 옮깁니다. 우리는 이러한 액션들이 Order 의 상태를 수정하는 것을 알고 있습니다. 왜냐하면 상태 개체 심볼들이 상태들을 가지기 때문입니다.



하위 활동 상태( Subactivity state )


하위 활동 상태( subactivity state ) 는 활동의 흐름에 다른 활동을 내포하고자 할 때 사용할 수 있는 또 다른 상태 다이어그램입니다. 하위 활동 상태는 활동 다이어그램에서 액션 상태가 위치한 곳에 배치됩니다. 액션 상태와 같은 방식으로 하위 활동 상태를 그릴 수 있는데, 우하단에 내포된 활동 다이어그램임을 표현하는 아이콘이 추가되어 있습니다. 하위 활동 상태의 이름은 Figure 15 와 Figure 16 에서 볼 수 있듯이 심볼 내에 위치합니다.


Figure 15 : IBM Rational XDETM 으로 그려진 하위 활동 상태의 예.


Figure 16: UML 명세에 그려진 하위 활동 상태의 예.


Figure 15 와 Figure 16 에서 우하단에 있는 하위 활동 상태 아이콘들이 약간 다르다는 점에 주목하십시오. UML 1.4 명시적으로 어떤 아이콘이 사용되어야 하는지에 대한 언급이 없습니다. 대신에 다음과 같이 이야기하고 있습니다:


하위 활동 상태는 액션 상태와 동일한 방식으로 표현되는데, 우하단에 내포된 활동 다이어그램을 표현하는 아이콘을 가지고 있다. 하위 활동 상태의 이름은 심볼 내에 위치한다. 하위 활동 상태는 다이어그램 내에서 유일할 필요는 없다. 이 표기법은 "내포된" 구조를 지원하는 모든 UML 생성에 적용된다. 아이콘은 내포된 구조의 형식을 암시해야만 한다.


지금으로썬 이것이 표준 심볼이 없다는 것을 의미합니다. 왜냐하면 하위 활동 상태 아이콘들이 누가( 혹은 어떤 도구가 ) 그것들을 활동 다이어그램에 넣느냐에 의존하기 때문입니다. 그래서 이 아이콘의 외형에 대한 확고한 동의에 도달할 때까지는 단순하게 일관성있는 것이 최선입니다: 하위 활동 상태를 표현할 때마다 같은 아이콘을 사용하는 것이 좋습니다.



결론



다른 UML 다이어그램들과 마찬가지로, 활동 다이어그램의 첫 번째 목적은 정보를 효율적으로 교환하는데 있습니다. 활동 다이어그램을 전체 시스템 모델에 포함하는 주요 이유는 그것들이 다양한 활동을 위한 절차적인 제어 흐름을 모델링한다는 것입니다. 이는 이러한 종류의 모델이 비즈니스를 하는 사람들이 시스템이 동작하는 비즈니스 환경에 대한 이해를 더 잘할 수 있게 해 주기 때문에 중요합니다. 물론, 활동 다이어그램은 비즈니스 처리를 모델링하는데만 국한되는 것은 아닙니다; 그것들은 컴퓨터 프로세스를 모델링하는 데도 사용될 수 있습니다.


일반적으로, 자신만의 활동 다이어그램을 생성할 때 이 기사에서 설명한 모든 표기 요소들을 사용하지는 않을 것입니다. 하지만 초기 상태, 전이 라인, 액션 상태, 최종 상태 표기들은 매우 자주 사용할 것입니다.


필수 UML 다이어그램에 대한 이 시리즈의 다음 기사에서는, 클래스 다이어그램에 대해서 세부적으로 다룰 것입니다. 올 가을에 다시 만납시다.




'ETC > Digital Painting' 카테고리의 다른 글

미사일  (0) 2016.04.07
물고기2  (0) 2015.10.15
물고기  (0) 2015.10.14
고양이 뼈대와 몸  (0) 2014.09.03
고양이 근육 연습  (0) 2014.08.31
고양이 뼈 연습 및 사이트 링크  (0) 2014.08.26
고양이과 골격 연습 측면  (0) 2014.08.24
얼굴 일부  (0) 2014.04.14
프로도????  (0) 2014.04.05
사람연습  (0) 2014.03.18



'ETC > Digital Painting' 카테고리의 다른 글

미사일  (0) 2016.04.07
물고기2  (0) 2015.10.15
물고기  (0) 2015.10.14
인간 뼈대  (0) 2014.09.09
고양이 근육 연습  (0) 2014.08.31
고양이 뼈 연습 및 사이트 링크  (0) 2014.08.26
고양이과 골격 연습 측면  (0) 2014.08.24
얼굴 일부  (0) 2014.04.14
프로도????  (0) 2014.04.05
사람연습  (0) 2014.03.18

근육 연습. 디테일을 하다가 지겨워서 중단.





'ETC > Digital Painting' 카테고리의 다른 글

미사일  (0) 2016.04.07
물고기2  (0) 2015.10.15
물고기  (0) 2015.10.14
인간 뼈대  (0) 2014.09.09
고양이 뼈대와 몸  (0) 2014.09.03
고양이 뼈 연습 및 사이트 링크  (0) 2014.08.26
고양이과 골격 연습 측면  (0) 2014.08.24
얼굴 일부  (0) 2014.04.14
프로도????  (0) 2014.04.05
사람연습  (0) 2014.03.18

캣 아나토미라는 고마운 사이트가 있어서 보고 연습함. http://www.familyvet.com/Cats/indexPG.html




'ETC > Digital Painting' 카테고리의 다른 글

물고기2  (0) 2015.10.15
물고기  (0) 2015.10.14
인간 뼈대  (0) 2014.09.09
고양이 뼈대와 몸  (0) 2014.09.03
고양이 근육 연습  (0) 2014.08.31
고양이과 골격 연습 측면  (0) 2014.08.24
얼굴 일부  (0) 2014.04.14
프로도????  (0) 2014.04.05
사람연습  (0) 2014.03.18
간만에 구연습  (0) 2014.02.04

"동물 & 인물 정밀묘사 테크닉" 보고 연습.


  • 가슴폭이 좁아서 다리가 벌어지지 않고 좁은 곳도 잘 다님.
  • 무게중심이 쏠려 엉덩이가 살짝 들린 듯이 그려야 함. 엉덩이가 좀 낮군...


'ETC > Digital Painting' 카테고리의 다른 글

물고기  (0) 2015.10.14
인간 뼈대  (0) 2014.09.09
고양이 뼈대와 몸  (0) 2014.09.03
고양이 근육 연습  (0) 2014.08.31
고양이 뼈 연습 및 사이트 링크  (0) 2014.08.26
얼굴 일부  (0) 2014.04.14
프로도????  (0) 2014.04.05
사람연습  (0) 2014.03.18
간만에 구연습  (0) 2014.02.04
Photoshop 구 연습  (0) 2013.12.02

그냥 따라 그려 봄. 완전 개판 ㅠㅠ 정성이 부족하다 ㅡㅡ;;




'ETC > Digital Painting' 카테고리의 다른 글

인간 뼈대  (0) 2014.09.09
고양이 뼈대와 몸  (0) 2014.09.03
고양이 근육 연습  (0) 2014.08.31
고양이 뼈 연습 및 사이트 링크  (0) 2014.08.26
고양이과 골격 연습 측면  (0) 2014.08.24
프로도????  (0) 2014.04.05
사람연습  (0) 2014.03.18
간만에 구연습  (0) 2014.02.04
Photoshop 구 연습  (0) 2013.12.02
Photoshop airbrush box 연습  (0) 2013.11.21

프로도를 그려보려고 했으나 실패... 기지도 못하는데 날려고 하다니 간단한 거부터 연습해야겠다.




'ETC > Digital Painting' 카테고리의 다른 글

고양이 뼈대와 몸  (0) 2014.09.03
고양이 근육 연습  (0) 2014.08.31
고양이 뼈 연습 및 사이트 링크  (0) 2014.08.26
고양이과 골격 연습 측면  (0) 2014.08.24
얼굴 일부  (0) 2014.04.14
사람연습  (0) 2014.03.18
간만에 구연습  (0) 2014.02.04
Photoshop 구 연습  (0) 2013.12.02
Photoshop airbrush box 연습  (0) 2013.11.21
Real 2B 로 원기둥 소묘  (0) 2013.11.19

Photoshop CC 를 지른 김에 연습해 보았다.


[ 인체의구조 ] 라는 책에 나온 사람...


Detail 을 많이 넣으려고 했는데, 그림이 잘 안 보이기도 하고 귀찮기도 하고... 대충했다.


말이 대충이지 한 4-5 시간은 걸린듯...





'ETC > Digital Painting' 카테고리의 다른 글

고양이 근육 연습  (0) 2014.08.31
고양이 뼈 연습 및 사이트 링크  (0) 2014.08.26
고양이과 골격 연습 측면  (0) 2014.08.24
얼굴 일부  (0) 2014.04.14
프로도????  (0) 2014.04.05
간만에 구연습  (0) 2014.02.04
Photoshop 구 연습  (0) 2013.12.02
Photoshop airbrush box 연습  (0) 2013.11.21
Real 2B 로 원기둥 소묘  (0) 2013.11.19
Light fringe 로 원기둥  (0) 2013.11.18

Adobe Photoshop Creative Cloud 시험판을 받아 보았다. Photoshop CS 6 와 동일한 듯 하다.


한글판으로 깔았기 때문에 좀 헷갈리는 것이 있긴 했지만 대충 원하는 brush 를 설정해서 구를 그려 봤다. "Airbrush" 가 "강화" 로 번역되다니 ㅡㅡ;;


대충 빠르게 그려 봤는데, 오랫만임에도 불구하고 한 번 해 봤던 거라 좀 감이 잡히는 것 같다.




'ETC > Digital Painting' 카테고리의 다른 글

고양이 뼈 연습 및 사이트 링크  (0) 2014.08.26
고양이과 골격 연습 측면  (0) 2014.08.24
얼굴 일부  (0) 2014.04.14
프로도????  (0) 2014.04.05
사람연습  (0) 2014.03.18
Photoshop 구 연습  (0) 2013.12.02
Photoshop airbrush box 연습  (0) 2013.11.21
Real 2B 로 원기둥 소묘  (0) 2013.11.19
Light fringe 로 원기둥  (0) 2013.11.18
Light fringe 집  (0) 2013.11.11

Photoshop 으로 구 연습


뭔가 우둘투둘한 느낌...


모니터가 이상해서 밝기 구분이 잘 안 되는데 다른 곳에서는 어떻게 보이는지 모르겠다.




'ETC > Digital Painting' 카테고리의 다른 글

고양이과 골격 연습 측면  (0) 2014.08.24
얼굴 일부  (0) 2014.04.14
프로도????  (0) 2014.04.05
사람연습  (0) 2014.03.18
간만에 구연습  (0) 2014.02.04
Photoshop airbrush box 연습  (0) 2013.11.21
Real 2B 로 원기둥 소묘  (0) 2013.11.19
Light fringe 로 원기둥  (0) 2013.11.18
Light fringe 집  (0) 2013.11.11
Light fringe 로 벽돌 연습  (0) 2013.10.30

학원에 디지털페인팅 수강 신청을 했다.


과제로 box gradation 을 그려보라고 해서 시도해 보았다. Gradation 이 참 어려운 주제였는데 점진적으로 색상을 만들어 가는 노가다를 통해서 한다는 것을 알게 되어서 좋았다.


역시 그림은 정성과 노가다 ㅠㅠ




'ETC > Digital Painting' 카테고리의 다른 글

얼굴 일부  (0) 2014.04.14
프로도????  (0) 2014.04.05
사람연습  (0) 2014.03.18
간만에 구연습  (0) 2014.02.04
Photoshop 구 연습  (0) 2013.12.02
Real 2B 로 원기둥 소묘  (0) 2013.11.19
Light fringe 로 원기둥  (0) 2013.11.18
Light fringe 집  (0) 2013.11.11
Light fringe 로 벽돌 연습  (0) 2013.10.30
Light fringe 로 cube 연습 2  (0) 2013.10.29

아무래도 소묘부터 제대로 안 되는 것 같아서 sketch 할때 좀 공을 들여서 해 봄.


개인적으로 그림은 얼마나 정성을 들이느냐가 중요한 듯... 그렇지만 아직도 채우지 못한 빈틈도 많고 gradation 도 제대로 안 됨.


필압도 그렇고 직접 그리는 것과는 느낌이 많이 달라서 익숙해져야 할 것 같다. 계속 연습해야할 듯.




'ETC > Digital Painting' 카테고리의 다른 글

프로도????  (0) 2014.04.05
사람연습  (0) 2014.03.18
간만에 구연습  (0) 2014.02.04
Photoshop 구 연습  (0) 2013.12.02
Photoshop airbrush box 연습  (0) 2013.11.21
Light fringe 로 원기둥  (0) 2013.11.18
Light fringe 집  (0) 2013.11.11
Light fringe 로 벽돌 연습  (0) 2013.10.30
Light fringe 로 cube 연습 2  (0) 2013.10.29
Light fringe 로 cube 연습  (0) 2013.10.27

Brush option 이 너무 어렵다. 진지하게 연구 좀 해봐야 겠다.


터치 개판이고 gradation 도 제대로 안 된다.




'ETC > Digital Painting' 카테고리의 다른 글

사람연습  (0) 2014.03.18
간만에 구연습  (0) 2014.02.04
Photoshop 구 연습  (0) 2013.12.02
Photoshop airbrush box 연습  (0) 2013.11.21
Real 2B 로 원기둥 소묘  (0) 2013.11.19
Light fringe 집  (0) 2013.11.11
Light fringe 로 벽돌 연습  (0) 2013.10.30
Light fringe 로 cube 연습 2  (0) 2013.10.29
Light fringe 로 cube 연습  (0) 2013.10.27
발 뼈  (0) 2013.10.13

Brush 설정 조정하면서 그려 봄. 좀 감이 오는 것도 같고... 하지만 detail 이 부족하고, pen 선 긋기가 잘 안 됨. 적어도 100% 로 해 놓고 칠해야 할 것 같음.





'ETC > Digital Painting' 카테고리의 다른 글

간만에 구연습  (0) 2014.02.04
Photoshop 구 연습  (0) 2013.12.02
Photoshop airbrush box 연습  (0) 2013.11.21
Real 2B 로 원기둥 소묘  (0) 2013.11.19
Light fringe 로 원기둥  (0) 2013.11.18
Light fringe 로 벽돌 연습  (0) 2013.10.30
Light fringe 로 cube 연습 2  (0) 2013.10.29
Light fringe 로 cube 연습  (0) 2013.10.27
발 뼈  (0) 2013.10.13
Light bristle 과 fractal water fringe wet 으로 눈 추가  (0) 2013.10.13

Light fringe 로 벽돌 연습을 했다.


이번에는 real water color 관련 brush property 들을 수정해 가면서 작업을 했다.


좀 더 해 보면 괜찮은 설정을 찾을 수 있을 것 같다. 한 번 brush property 들에 대해 정리해 봐야겠다.




'ETC > Digital Painting' 카테고리의 다른 글

Photoshop 구 연습  (0) 2013.12.02
Photoshop airbrush box 연습  (0) 2013.11.21
Real 2B 로 원기둥 소묘  (0) 2013.11.19
Light fringe 로 원기둥  (0) 2013.11.18
Light fringe 집  (0) 2013.11.11
Light fringe 로 cube 연습 2  (0) 2013.10.29
Light fringe 로 cube 연습  (0) 2013.10.27
발 뼈  (0) 2013.10.13
Light bristle 과 fractal water fringe wet 으로 눈 추가  (0) 2013.10.13
Round water brush 로 눈꺼풀 연습  (0) 2013.10.13

또 cube 연습.


뭔가 지저분... gradation 이 잘 안 됨.




'ETC > Digital Painting' 카테고리의 다른 글

Photoshop airbrush box 연습  (0) 2013.11.21
Real 2B 로 원기둥 소묘  (0) 2013.11.19
Light fringe 로 원기둥  (0) 2013.11.18
Light fringe 집  (0) 2013.11.11
Light fringe 로 벽돌 연습  (0) 2013.10.30
Light fringe 로 cube 연습  (0) 2013.10.27
발 뼈  (0) 2013.10.13
Light bristle 과 fractal water fringe wet 으로 눈 추가  (0) 2013.10.13
Round water brush 로 눈꺼풀 연습  (0) 2013.10.13
Light bristle 로 안구 연습  (0) 2013.10.12

수채화라는 것이 가장 쉬운 듯 보이면서도 막상 painter 로 칠해 보면 참 어렵다는 것을 느끼게 된다. 도약아트에서 교육신청해서 수채화 초급 강의를 듣고 있는데, 내 생각에는 칠했을 때 실체 수채화 brush 와 가장 비슷한 느낌을 내는 brush 가 light fringe 와 melted flow 인 것 같다.


그 중에서 light fringe 로 cube 를 그려 보았다. 느낌에 익숙해지기 위해서 많은 시간이 필요했다. 물론 아직까지도 연습이 많이 필요하다.


'ETC > Digital Painting' 카테고리의 다른 글

Real 2B 로 원기둥 소묘  (0) 2013.11.19
Light fringe 로 원기둥  (0) 2013.11.18
Light fringe 집  (0) 2013.11.11
Light fringe 로 벽돌 연습  (0) 2013.10.30
Light fringe 로 cube 연습 2  (0) 2013.10.29
발 뼈  (0) 2013.10.13
Light bristle 과 fractal water fringe wet 으로 눈 추가  (0) 2013.10.13
Round water brush 로 눈꺼풀 연습  (0) 2013.10.13
Light bristle 로 안구 연습  (0) 2013.10.12
Dry on dry paper box 연습  (0) 2013.09.22

발이란, 항상 이상하게 생겼고 그리기 어려운 것이라 생각해 왔다.


지금도 마찬가지지만 발 뼈가 어떻게 생겼는지 알고 나니 좀 더 그리는 데 도움이 되는 것 같다.




음... 선명한 선의 느낌을 주고 싶었는데 속눈썹이 상당히 굵다. 그리고 눈과 같이 유리질을 잘 표현하지 못하겠다. 이것저것 많이 해 봐야 할듯.




'ETC > Digital Painting' 카테고리의 다른 글

Light fringe 집  (0) 2013.11.11
Light fringe 로 벽돌 연습  (0) 2013.10.30
Light fringe 로 cube 연습 2  (0) 2013.10.29
Light fringe 로 cube 연습  (0) 2013.10.27
발 뼈  (0) 2013.10.13
Round water brush 로 눈꺼풀 연습  (0) 2013.10.13
Light bristle 로 안구 연습  (0) 2013.10.12
Dry on dry paper box 연습  (0) 2013.09.22
[ Painter tutorial 따라하기 ] 춘리 : Basic Color  (0) 2013.08.28
[ Painter Tutorial 따라하기 ] 춘리 : clean lines  (0) 2013.08.26

Digital water color brush 중에서 round water brush 를 사용함. 

Blending 을 잘 못해서 그런지 부자연스럽고 지저분해 보임. 

볼륨감 표현이 원하는 대로 잘 안 됨.

반복적인 연습이 필요할듯.




Light bristle 의 사용법에 대해서 잘 이해를 못하고 있었는데, 조금은 이해를 할 수 있을 것 같다.


Light bristle 의 느낌은 다음과 같다.


  • 붓의 궤적이 남는다.
  • 겹쳐 그리는 부분에 밝은 색이 나온다.
  • 어두운 부분부터 그린 다음에 위쪽에 밝은 색을 그리는 것이 좋다. --> 반사광같은거 표현하기 괜찮은듯.
  • Detail 은 무조건 나중에 그려야만 한다. 겹쳐 그리면 detail 이 다 깨진다.




Dry on dry paper brush 를 이해하기 위해 box 를 그려 보았다. 계속 겹쳐 그리면 어두워지는데... 약간 물이 적고 채도가 낮아서 그런지 목탄 느낌???

 

 

 

 

+ Recent posts