<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://mediawiki.zeropage.org/index.php?action=history&amp;feed=atom&amp;title=%EB%A0%88%EB%B0%8D%EC%A6%88%ED%94%84%EB%A1%9C%EC%A0%9D%ED%8A%B8%2F%ED%94%84%EB%A1%9C%ED%86%A0%ED%83%80%EC%9E%85%2F%EC%97%90%EB%8B%88%EB%A9%94%EC%9D%B4%EC%85%98</id>
	<title>레밍즈프로젝트/프로토타입/에니메이션 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://mediawiki.zeropage.org/index.php?action=history&amp;feed=atom&amp;title=%EB%A0%88%EB%B0%8D%EC%A6%88%ED%94%84%EB%A1%9C%EC%A0%9D%ED%8A%B8%2F%ED%94%84%EB%A1%9C%ED%86%A0%ED%83%80%EC%9E%85%2F%EC%97%90%EB%8B%88%EB%A9%94%EC%9D%B4%EC%85%98"/>
	<link rel="alternate" type="text/html" href="https://mediawiki.zeropage.org/index.php?title=%EB%A0%88%EB%B0%8D%EC%A6%88%ED%94%84%EB%A1%9C%EC%A0%9D%ED%8A%B8/%ED%94%84%EB%A1%9C%ED%86%A0%ED%83%80%EC%9E%85/%EC%97%90%EB%8B%88%EB%A9%94%EC%9D%B4%EC%85%98&amp;action=history"/>
	<updated>2026-05-16T00:48:45Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.39.8</generator>
	<entry>
		<id>https://mediawiki.zeropage.org/index.php?title=%EB%A0%88%EB%B0%8D%EC%A6%88%ED%94%84%EB%A1%9C%EC%A0%9D%ED%8A%B8/%ED%94%84%EB%A1%9C%ED%86%A0%ED%83%80%EC%9E%85/%EC%97%90%EB%8B%88%EB%A9%94%EC%9D%B4%EC%85%98&amp;diff=85551&amp;oldid=prev</id>
		<title>Maintenance script: Repair batch-0005 pages from live compare</title>
		<link rel="alternate" type="text/html" href="https://mediawiki.zeropage.org/index.php?title=%EB%A0%88%EB%B0%8D%EC%A6%88%ED%94%84%EB%A1%9C%EC%A0%9D%ED%8A%B8/%ED%94%84%EB%A1%9C%ED%86%A0%ED%83%80%EC%9E%85/%EC%97%90%EB%8B%88%EB%A9%94%EC%9D%B4%EC%85%98&amp;diff=85551&amp;oldid=prev"/>
		<updated>2026-03-27T00:44:57Z</updated>

		<summary type="html">&lt;p&gt;Repair batch-0005 pages from live compare&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 00:44, 27 March 2026&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l4&quot;&gt;Line 4:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 4:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;추상화 기초 클래스.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;추상화 기초 클래스.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;AddFrame(UINT ITEM)으로 프레임을 추가시키고 외부에서 적절한 타이머를 통해서 움직임을 조절한다.(NextFrame())&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;AddFrame(UINT ITEM)으로 프레임을 추가시키고 외부에서 적절한 타이머를 통해서 움직임을 조절한다.(NextFrame())&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;[[:File:&lt;/del&gt;beonit.exe&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;|beonit.exe]]&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;beonit.exe&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;= 코드 =&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;= 코드 =&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;  class CmyAnimation{&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;  class CmyAnimation{&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Maintenance script</name></author>
	</entry>
	<entry>
		<id>https://mediawiki.zeropage.org/index.php?title=%EB%A0%88%EB%B0%8D%EC%A6%88%ED%94%84%EB%A1%9C%EC%A0%9D%ED%8A%B8/%ED%94%84%EB%A1%9C%ED%86%A0%ED%83%80%EC%9E%85/%EC%97%90%EB%8B%88%EB%A9%94%EC%9D%B4%EC%85%98&amp;diff=50067&amp;oldid=prev</id>
		<title>imported&gt;Unknown at 05:29, 7 February 2021</title>
		<link rel="alternate" type="text/html" href="https://mediawiki.zeropage.org/index.php?title=%EB%A0%88%EB%B0%8D%EC%A6%88%ED%94%84%EB%A1%9C%EC%A0%9D%ED%8A%B8/%ED%94%84%EB%A1%9C%ED%86%A0%ED%83%80%EC%9E%85/%EC%97%90%EB%8B%88%EB%A9%94%EC%9D%B4%EC%85%98&amp;diff=50067&amp;oldid=prev"/>
		<updated>2021-02-07T05:29:22Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;[[레밍즈프로젝트]], [[레밍즈프로젝트/프로토타입]]&lt;br /&gt;
----&lt;br /&gt;
= 코드 설명 =&lt;br /&gt;
추상화 기초 클래스.&lt;br /&gt;
AddFrame(UINT ITEM)으로 프레임을 추가시키고 외부에서 적절한 타이머를 통해서 움직임을 조절한다.(NextFrame())&lt;br /&gt;
[[:File:beonit.exe|beonit.exe]]&lt;br /&gt;
= 코드 =&lt;br /&gt;
 class CmyAnimation{&lt;br /&gt;
 protected:&lt;br /&gt;
 	vector&amp;amp;lt;UINT&amp;amp;gt; m_frameList;&lt;br /&gt;
 	int m_nowFrame;&lt;br /&gt;
 &lt;br /&gt;
 private:&lt;br /&gt;
 	void init(){&lt;br /&gt;
 		m_nowFrame = 0;&lt;br /&gt;
 	}&lt;br /&gt;
 public:&lt;br /&gt;
 	CmyAnimation(){&lt;br /&gt;
 		init();&lt;br /&gt;
 	}&lt;br /&gt;
 	void nextFrame(){&lt;br /&gt;
 		if(m_nowFrame &amp;amp;lt; int(m_frameList.size())-1)&lt;br /&gt;
 			m_nowFrame++;&lt;br /&gt;
 		else m_nowFrame = 0;&lt;br /&gt;
 	}&lt;br /&gt;
 	int getFrameSize(){&lt;br /&gt;
 		return int(m_frameList.size());&lt;br /&gt;
 	}&lt;br /&gt;
 	void addFrame(UINT ITEM){&lt;br /&gt;
 		m_frameList.push_back(ITEM);&lt;br /&gt;
 	}&lt;br /&gt;
 	virtual void drawFrame(CmyDouBuffDC* dc)=0;&lt;br /&gt;
 };&lt;br /&gt;
----&lt;br /&gt;
= GIF 포기 =&lt;br /&gt;
== 결론 ==&lt;br /&gt;
자동적인 에니메이션은 불가능. 프레임마다 에니메이션 객체가 스스로의 상태를 파악하여 새로 BMP를 뿌려 주어야 함.&lt;br /&gt;
== 왜? ==&lt;br /&gt;
CDC를 확장한 [[레밍즈프로젝트/그리기DC]]에 자동 에니메이션을 구현 하고자 하였다.&lt;br /&gt;
하지만 OnDraw에서 생성되고 파괴되는 그리기DC에서 프레임단위의 에니메이션 처리는 옳지 않다. 만약 하게 된다면 모든 레밍들의 객체를 그리기DC안에 넣어야 할 것이다.&lt;br /&gt;
== 대안 ==&lt;br /&gt;
대안. 수동으로 진행되는 에니메이션 작업을 클래싱 할 수 있을 듯-_- 버튼에서 활용 가능 할 듯&lt;br /&gt;
== CmyAnimation ==&lt;br /&gt;
에니메이션이 필요한 객체들은 이 클래스를 상속 받음으로서 에니메이션 처리를 할 수 있다.&lt;br /&gt;
이 클래스는 더블버퍼링과 bmp그리기를 자동화 시켜둔 [[레밍즈프로젝트/그리기DC]](CmyDouBuffDC)를 사용하여 드로잉을 수행한다. (CDC를 사용하는 도 있지만... 편의를 위해서...)&lt;br /&gt;
----&lt;/div&gt;</summary>
		<author><name>imported&gt;Unknown</name></author>
	</entry>
</feed>