'Application'에 해당되는 글 177건
- 2008.03.14 flex :: Sample Chart
- 2008.03.13 flex :: unable to load SWC Cairngorm.swc: multiple points
- 2008.03.10 java :: Collection - Collection, ArrayList, HashTable
- 2008.03.10 java :: Java Map(HashMap, TreeMap, Hashtable) 1
- 2008.03.10 java :: [컬렉션] Collection / HashTable
- 2008.03.10 flex :: DataGrid Row 배경색 바꾸기
- 2008.03.10 flex :: Flex DataGrid 컬럼 동적 생성
- 2008.03.06 java :: iterator 주의사항
- 2008.03.06 java :: 자바실행 파일 만들기
- 2008.02.28 flex :: chart 퍼센테이지 및 기본 설정
unable to load SWC multiple points
Cairngorm Framework 강좌를 보면서 따라하기 했습니다...
하지만 아래와 같은 문구의 오류가 나더군요
unable to load SWC Cairngorm.swc: multiple points
구글검색도 해봤지만 영문 ㅡㅡ;;; 머 대충 네이버 툴바 이용해서 단어 하나씩 해결하면서 보니까
Here are the steps:
- Download the Cairngorm src .zip
- Unzip into a folder on your machine
- Import the .project file into Flex Builder
- Hit Project -> Clean for a nice clean build
요런 게 있더군요 하지만 이방법으로도 되지 않는다!
그러면 플렉스 버전 확인해보세요 ㅋㅋㅋ
테스트 환경이 노트북과, 데스크탑으로 했는데
노트북의 경우 플렉스 2.0.1 이였고
데스크탑의 경우 플렉스 2.0.1. 123.... 머시긴가 여튼 좀 길었습니다.
결과 노트북은 위와 같은 메시지가 뜨지 않터군요
데스크탑은 여전히 저런 메시지를 팍팍 뿌려 주면서 캔곰을 못 쓰게 만들고요 ㅡㅡ;;;
그래서 데스크탑의 플렉스 버전도 2.0.1로 바꿧습니다 ㅋㅋ 되내요 ㅋㅋㅋㅋ 야호 ㅋㅋㅋ
다른분들도 혹시 이런 메시지나 오류가 나면 플렉스 버전을 2.0.1로 마춰보세요 ㅡㅡV
플렉스 버전 2.0.1 에는 정상작동
플렉스 버전 2.0.1 14.. 머시기는 작동 불등
상위 버전은 모르겠음 ^^;;;
unable to load SWC Cairngorm.swc: multiple points
Flex Builder Version 2.0.1 !!!!
Version 2.0.1 14.... NO!!
Only Version 2.0.1!!
Collection, ArrayList, HashTable
Collection
1. Collection의 이해
1) 배열의 경우 인덱스를 사용하여 각 항목(element)에 접근하게 되는데, collection은 인덱스를 사용하지 않고 모든 element에 순차적으로 접근할 수 있는 방법을 제공하는거야.
2) 각 element에 순차적으로 접근할 수 있도록 허용하는 객체의 집합이야.
3) 객체가 열거자(enumerator)라고 불리는 객체의 참조를 제공하면 collection이라 해.
4) 열거자는 collection 내의 항목을 순차적으로 액세스할 수 있어.
5) Foreach를 통해 객체내에 순차적으로 접근할 수 있도록 기능을 제공한다.
2. Collection의 동작
1) collection이 foreach 와 함께 사용될 때 foreach는 자동적으로 collection의 IEnumerable interface로부터 GetEnumerator() method를 호출
2) GetEnumerator()는 Ienumerable interface를 구현한 열거자 객체(enumerator object)를 return
3) foreach는 이 열거자 객체로부터 IEnumerable interface를 얻어 method(MoveNext(), Reset())와 property(Current)를 호출
3. Custom Collection
1) collection을 만들려면 System.Collections namespace의 IEnumerable interface를 구현해야해.
IEnumerable interface
{
IEnumerable GetEnumerator(); // 열거자 객체를 반환
// 얘가 제공되어야지만 collection이라고 불릴 수 있는거야.
}
2) 열거자 객체는 System.Collection의 IEnumerable를 구현하는거야.
Interface IEnumerator
{
object Current { get; } // Current 라는 프로퍼티는 get이라는 접근자만 제공하고 있어.
bool MoveNext();
void Reset();
}
4. Custom Collection 작동모습
1) IEnumerator를 구현한 class의 객체는 다음과 같이 작동을 구현해.
(1) 객체 초기화시 어떤 element도(항목) 가리키지 않음
(2) MoveNext method를 호출하여 첫번째 element로 이동해.
(3) Current property를 통해 element를 뽑아내는거야.
- Current property는 객체의 reference를 return하므로 이것을 찾고자 하는 객체의 형식으로 cast해서(안에 저장된 데이터의 타입으로) 필요한 작업을 수행
(4) MoveNext를 호출하여 다음 element로 이동
(5) 위 과정을 마지막까지 반복.
(6) Current property가 null을 return 하면 더 이상 접근할 항목이 없다는 의미
(그래서 항상 루프를 돌릴 때 Current가 null인지 아닌지를 체크해야해)
(7) Reset method 를 호출하여 처음으로 돌아가거나 , 처리종료
(8) Reset 호출시에는 첫번째 element 의 이전을 가르키므로 MoveNext를 통해서 첫번째 항목으로 이동해서 순차적으로 접근을 해야해.
ArrayList
1. ArrayList의 이해
1) 객체를 배열로 만들어 사용하는데 유용한 기능을 제공
2) 확장성이 뛰어나 삽입/삭제/열거 등의 기능을 제공
3) 배열의 크기를 초기에 지정할 수 있어.
4) 정의된 크기를 초과하면 자동으로 크기를 늘려줘.
2. ArrayList와 Collection의 관계
1) ArrayList라는 자체가 IEnumerable interface를 통해서 구현된 클래스야. (상속을 받어)
때문에 ArrayList의 GetEnumerator를 통해 열거자객체를 얻을 수 있어.
(여기서도 foreach문을 사용할 수 있게 되는거야)
2) 이를 통해 순차적으로 ArrayList에 접근할 수 있어.
3. ArrayList 사용법
1) 생성 및 초기화
ArrayList myAL = new ArrayList(); // ArrayList 생성
myAl.Add(new Car(“그랜져”, 100000)); // 초기화, Car type의 data가 ArrayList에 저장
myAl.Add(new Car(“체어맨”, 200000));
myAl.Add(new Car(“포텐샤”, 300000));
2) ArryList 정보
myAL.Count; // 실제로 저장된 element 수
int MaxSize = myAL.Capacity; // Capacity가 하는 일은 현재 ArrayList 총 크기 얻기지.
myAL.Capacity = 20; // 저장될 수 있는 총 용량 설정(default는 16)
3) element(항목) 제거
myAL.RemoveAt(1); // 0부터 시작해서 지정된 요소를 제거, 1이면 두번째위치의 녀석이지
4) ArrayList를 배열로 변환
- parameter를 배열로 전달해야 하는 경우에 사용(Type 변환 주의)
Car[] CarArray = new Car[myAL.Count]; // 저장될 배열 생성
for(int i=0; i<myAL.Count; i++) { // 배열에 ArrayList 정보 저장
CarArray[i] = (Car)myAL[i]; // Car type으로 명시적 형변환하고 있어. 꼭 형변환해야해
}
foreach(Car i in CarArray) { // 배열 출력
Console.WriteLine(“차종 : {0}, 가격 : {1}”, i.carName, i.carPrice);
}
HashTable
1. HashTable의 이해
1) 특정 Key 값에 의해 element에 접근할 수 있도록 고안된 데이터 구조
2) 어떠한 형태의 객체든 저장이 가능해(ArrayList도 가능해)
Hashtable hash1 = new Hashtable(); // HashTable 객체 선언
Hash.Add(“847361”, “홍길동”); // Add method를 통한 등록
Hash.Add(“127561”, “박길동”); // 첫번째가 키값, 두번째가 항목에 들어갈 데이터
Hash.Add(“887261”, “김길동”);
Hash.Add(“234561”, “이길동”);
foreach (string item1 in hash1.Keys) { // key data type에 의한 foreach 출력
// 위에 놈은 위 string인가. 그건 홍길동의 type이 string이기 때문이야
Console.WriteLine(item1 + “ “ + hash1[item1]);
}
Collection, ArrayList, HashTabled 의 공통점은?
비슷한 특징이 있어. 객체를 배열로 묶어서 저장하고 그 배열에 대해서 순차적으로 foreach문을 통해서 자동적으로 접근할 수 있도록 기능을 제공하고 있지.
--------------------------------------------------------------------------------------------------------------
자, 이제 예문을 통해 알아보자.
// 기본적인 기능을 가지고 있는 Collection를 만들어볼꺼야 #################
class MyCollection
{
// 보통은 private로 많이 하나 예제니 간단하게 public으로 만들자
public int[] items; // 배열 생성
int nIndex = -1; // 변수 생성
MyCollection collection; // 변수 생성..... 안에서 items를 계속 접근할려고 만들었어.
// 생성자에서는 collection에다가 현재객체를 담도록 지정해볼꺼야.
public MyCollection()
{
collection = this; // 여기에는 Reference가 담기게 되는거야.
}
public MyCollection GetEnumerator()
{
return this; // MyCollection를 리턴하도록 설정했어.
}
// 이 MoveNext를 통해 이동하고 Current를 통해 데이터를 뽑아내는거야.
public bool MoveNext()
{
nIndex++;
return(nIndex < collection.items.GetLength(0));
// 배열에 접근할 수 있는 배열첨자의 역할을 int type변수
}
public void Reset()
{
// nIndex 배열을 초기화해줄것
nIndex = -1;
}
public int Current
{
get { return(collection.items[nIndex]); }
}
}
// ######################################################
class MyClass
{
public static void Main()
{
// 위에서 Collection을 만들었으니 객체를 만들어서 순차적으로 접근해보자.
MyCollection col = new MyCollection();
col.items = new int[5]{11, 33, 22, 55, 44}; // 5개의 int type Array 생성
// 콜렉션같은 경우는 foreach문을 통해 순차적인 접근이 가능해.
foreach(int i in col)
{
Console.WriteLine(i);
}
}
}
▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒
// 학습목료
// : 학교에 등교하는 학생의 정보를 저장해볼꺼야.
using System;
using System.Collections; // -> 이 부분을 참조했어. (네임스페이스)
class Student
{
// 멤버들을 기술할꺼야. 예제를 위해 public으로 구성할꺼야.
public string name; // 학생 이름
public int no; // 학생 번호
// ###생성자를 생성###
public Student(){}
public Student(string name, int no)
{
this.name = name; // 초기화
this.no = no; // 초기화
}
}
class Myschool
{
public static void Main()
{
// 나왔다. ArrayList ~
ArrayList myAL = new ArrayList();
// 어짜피 레퍼런스타입으로 저장되기에 new를 사용했어.
myAL.Add(new Student("홍길동", 20)); // 학생 객체를 Array를 통해 생성
myAL.Add(new Student("지니진", 10));
myAL.Add(new Student("이순신", 30));
// 홍길동을 삭제할꺼야~
myAL.RemoveAt(0);
// 그럼 출력해보자.
// 현재는 Student type Data를 가지고 있어. 우리는 ArrayList 자체가 아니라 Student 객체에 대한 데이트들.
// 그래서 Student type으로 변환해야해.
for(int i=0; i<2; i++)
{
// 여기서 Student type으로 형변환을 해줄꺼야
Console.WriteLine("이름 : {0}, 번호 : {1}", ((Student)myAL[i]).name, ((Student)myAL[i]).no);
}
Console.WriteLine();
// 이번에는 배열로 바꿔보자. -------------------------------------------------------------------------------------------
// Student 라는 클래스에 데이터가 들어가 있어. 배열로 Student type으로 배열로 만들꺼야.
Student[] StudentArray = new Student[myAL.Count]; // 객수만큼 만들어.. 2인 배열이 생성되겠지
// for문을 통해서 알아보자
for(int i=0; i<myAL.Count; i++)
{
// Student Array 에 Student type으로 저장하는거야.
// 파라미터나 foreach문으로 출력이 가능해
StudentArray[i] = (Student)myAL[i];
}
foreach(Student i in StudentArray)
{
Console.WriteLine("이름 : {0}, 번호 : {1}", i.name, i.no);
}
}
}
▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒
// 학습목료
// : 학교에 등교하는 학생의 정보를 저장해볼꺼야.
// ArrayList 같은경우 아이이뉴멀오프 인터페이스를 실제로 구현하면
// foreach문을 통해 접근할수 있어.
using System;
using System.Collections; // -> 이 부분을 참조했어. (네임스페이스)
class MyHashTable
{
public static void Main()
{
// 배열같은 경우는 인덱스값이 int type만 가능하나 해쉬 테이블을 달라
// 문자열이나 기타 다른 타입으로도 가능하다는 거야.
Hashtable hash1 = new Hashtable();
hash1.Add("111111", "홍길동"); // 앞이 키값, 뒤가 항목
hash1.Add("222222", "임꺽정");
hash1.Add("333333", "이순신");
// 그럼 출력해보자
foreach(string item in hash1.Keys)
{
Console.WriteLine(item + " " + hash1[item]);
}
// 항목을 삭제해보자.
hash1.Remove("222222");
foreach(string item in hash1.Keys)
{
Console.WriteLine(item + " " + hash1[item]); // 임꺽정이 지워진것을 알수있어.
}
}
}
▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒
1. Collection | |
| |
2. HashMap | |
| |
3. TreeMap | |
| |
4. Hashtable | |
|
보통은 컬렉션을 배열로 구현을 하는게 맞다.
사용하는 입장이라면 기존의 있는 자료형을 그대로 쓰는게 좋겠지.
우리는 컬렉션을 다루기가 쉽거든.
배열과 컬렉션의 선택기준
단일타입의 집합은 배열을 쓰자.
배열은 막무가내로 짜지 않는다. 중학교 관리프로그램이라고 치면 어느정도 예상치를 알기에
적정하게 잡고 만들지.
다중타입의 집합은 컬렉션을 쓰자. 가변적인 방의 갯수.. 배열과 달리 줄이거나 늘리는데 유동적.
배열이나 컬렉션을 만들고 탐색을 많이 하지.
아이템에 대한 접근을 하는데 배열은 for문을 쓰고 컬렉션은 foreach문 쓰자. 실제 컬렉션은 for문
보다 foreach문이 월등히 빠르다.
배열과 컬렉션의 차이점.
[배열]
: 데이터의 집합, 배열도 오브젝트형을 만들 수 있다. 배열은 고정된 크기만 갖는다.
첨에 방이 10개면 계속 10만 가능하다.
[컬렉션]
: 다중 데이터형 집합, 오브젝트형의 집합
동적으로 메모리 확장가능(크기가 가변적이다, 가장 많이 쓰는 이유)
확실하지 않은 데이터의 크기는 컬렉션을 많이 쓰지.
방을 늘리거나 줄이거나 가능하기 때문이야
ArrayList
- 크기가 필요에 따라 동적으로 증가되는 배열
- 데이터를 넣을때
list.Add();
Ilist : 아이리스트를 부모로 갖는(상속) 놈들은 인덱서를 쓰도록 하자
Array list = new Array(); -> list[0]
이런 방법으로 입/출력할 수 있는 것.
ICollection : 얘를 상속받은 모든 클래스는 자기가 가지고 있는 구성요소를 count
라는 이름으로 반환하게 되어 있어.
쩜.count 이런 식으로 쓰인다.
IEnumerable : 도움말 참조~
ICloneable : clone 이라는 메소드를 구현해야 한다. 왜 배열을 clone으로 카피하는 이유
list.clone(); 복사할 때 이런 문법을 쓰는데 이 인터페이스를 상속받았기
때문이야.
개념을 알고 가자
Add : 추가의 개념, 다른 메소드에서는 Append 라고도 한다. 내용이 있으면 밑에다 계속 추가.
Insert : 삽입의 개념. 자료가 있으면 사이에 비짚고 넣겠다는 거야.
가변적인 ArrayList 왜???
배열은 방을 만들면 끝이다. int[] num = new int[5];
그러나 이놈은 신기하게 방갯수 변경이 가능하다. 하지만 이놈도 원래 방의 크기가 있다.
ArrayList mm = new ArrayList();
list.Add(10);
list.Add(20);
list.Add(30);
원래 기본적으로 3개의 방이 생성이 되는데 4번째 방을 만들고자 Add로 넣으면
기본크기의 2배가 되는 방을 만들고 원래있던 값들을 복사한다.
list.Add(40);
내부적으로는 객체가 2번 생성이 된것이지.. 그리고 방의 크기는 6개가 되는거야.
보통 기본크기도 잡을 수 있다.
근데 항상 요소의 갯수가 100개와 101개를 넘나들면 빈방이 많아지겠지.
이까지는 좋아. 4번째방에 40을 넣으면 2개의 남는 방이 있잖아.
이 때, 죽어도 4개이상의 방을 넘어갈 일이 없다... 즉 남는방을 없앨 때
우리는 list.TrimToSize(); 를 써서 공간낭비를 줄일 수 있다.
========================================================================================
using System;
using System.Collections; // 컬렉션을 구동하기 위해 추가하는 using문
namespace ConsoleApplication1
{
public class Class6
{
public static void Main(string[] args)
{
// 배열같은 놈을 하나 만들자
// #### ArrayList #########
// 배열과 달리 길이가 가변적이라 방의 갯수를 지정할 필요 없다.
// foreach문을 지원한다.
ArrayList list = new ArrayList();
list.Add(100);
list.Add(200);
list.Add(300);
Console.WriteLine("list의 크기 : {0}", list.Count); // 3 을 반환
Console.WriteLine(list[1]); // 200 을 반환
foreach(int n in list)
{
Console.WriteLine(n); // 100 200 300 을 반환
}
// 요소를 모두 제거하는 clear
list.Clear();
Console.WriteLine(list.Count); // 0 을 반환
// 지운 값을 다시 넣고...
list.Add(100);
list.Add(200);
list.Add(300);
// 유/무를 반환, 검색용 메소드
Console.WriteLine(list.Contains(200)); // true를 반환
// Insert....
list.Insert(1,400); // 1번째 위치에 400을 넣겠다는 의미다.
foreach(int n in list)
{
Console.WriteLine(n);
}
// Insert를 ADD랑 같게 만들고 싶다면
list.Insert(list.Count, 777);
foreach(int n in list)
{
Console.WriteLine(n);
}
// Remove는 찾아서 지우는 놈.... 200을 넣으면 200이란 값을 찾아서 지운다.
// 만약 200이 두개 있으면 첫번째 놈만 지운다.
list.Remove(200);
// 찍어서 지운다.
list.RemoveAt(1);
// sort는 배열의 sort와 같다.
list.Sort();
// 이놈은 쓰는게 좋다.
// 왜 이 ArrayList란 놈은 가변적일까???
// 그 질문과 연장선상에 있다. 이놈은 남는 방을 잘러버리거든
list.TrimToSize()
▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒
HashTable
IDictionary 기능을 가지고 있다. 방이름(키값)을 지정해주는것
이 놈은 hash[0] 이라고 하면 0번째 방이 아닌 0의 키값을 가지는지 보는거야..
패턴이 없기 때문에 반복시키기가 좀 애매해.. 못하는건 아닌데 많이 까다로워
직관적인 대신에 이런 약점을 가지지...
list[0] - "스칼라배열", 인덱스로 구분
list["id"] - "연관배열", HashTable
// 사용자의 입장에서 주소값만 보고는 사실 머가 들어있는지 잘 모르잖아
// 근데 방이름만 잘 정해주면 방속에 있는 데이터가 먼지를 어느정도 알수있잖아~
Hashtable hash = new Hashtable();
hash.Add("one", "하나");
hash.Add("two","둘");
hash.Add("three","셋");
hash.Add("402","닷넷전문가");
hash.Add("301","DB전문가");
// Hashtable을 불러내기 위해서는 방의 이름표(키값)를 요구한다.
// ADD 할때 키와 값의 쌍으로 이루어지게 된다.
Console.WriteLine(hash["one"]);
Console.WriteLine(hash["402"]);
Console.WriteLine(hash[0]); // 0번째 방이 아닌 0의 키값을 찾아보는거다.
// Queue, 입/출력 데이터는 역시 오브젝트이다.
// 선입선출(FIFO : first in first out) : 파이프에 공을 넣고 끝에서 하나씩 받는다고 생각해.
// 우리가 쓰는 원도우에 딜레이가 있어도 먼저 클릭한 것부터 진행하잖아~
// 이는 메시지를 담아놓는 Queue가 존재해서 그래.
Queue queue = new Queue();
queue.Enqueue(10);
queue.Enqueue(20);
queue.Enqueue(30); // 차곡차곡 순서대로 데이터를 넣었다.
// 데이터를 끄집에 낼때는 단순한 메소드 호출 10->20->30의 순서로 호출된다.
Console.WriteLine(queue.Count); // 3 이 호출
Console.WriteLine(queue.Dequeue());
Console.WriteLine(queue.Dequeue());
Console.WriteLine(queue.Dequeue());
Console.WriteLine(queue.Count); // 0 이 호출 : Dequeue()라는 놈은 가져온 만큼 데이터 소멸
queue.Enqueue(500);
Console.WriteLine(queue.Peek()); // 요소를 제거하지 않고 그냥 반환.. 데이터 소멸 X
Console.WriteLine(queue.Count); // 1 이 호출
// Stack =========================================================
// 후입후출(LIFO : last in first out) 맨 마지막에 들어간 놈이 맨 첨에 나온다.
// 바닥이 막힌 세로로 생긴 통이라고 생각해라.
Stack stack = new Stack();
stack.Push("일");
stack.Push("이");
stack.Push("삼");
Console.WriteLine(stack.Count); // 3 이 호출
Console.WriteLine(stack.Pop()); // "삼" 이 호출
Console.WriteLine(stack.Pop()); // "이" 가 호출
Console.WriteLine(stack.Pop()); // "일" 이 호출
Console.WriteLine(stack.Count); // 0 이 호출
stack.Push("십");
Console.WriteLine(stack.Peek()); // "십" 이 호출
Console.WriteLine(stack.Count); // 1 이 호출
▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒
}
}
}
[출처] [컬렉션] Collection / HashTable|작성자 지니진
How to change the background color of a row is an often-asked question. In Flex 2.0 it is easy. Follow these steps:
- Create a new class that extends mx.controls.DataGrid. This class can be an MXML file or an ActionScript file, whichever you are most comfortable with.
- Overide the protected function, drawRowBackground:
override protected function drawRowBackground(s:Sprite, rowIndex:int, y:Number, height:Number,
color:uint, dataIndex:int):void
{
// make any tests here, then change color accordingly. For example: color = 0xFF0000;
// call the super function to make it happen.
super.drawRowBackground(s,rowIndex,y,height,color,dataIndex);
} - Now use your new grid in place of the <mx:DataGrid> in your application.
Within drawRowBackground you can test your data. The dataIndex argument can be used to look up the item in the dataProvider that corresponds to this row. For example, suppose you want to color any row green whose quantity is greater than 1000:
var item:Object = (dataProvider as ArrayCollection).getItemAt(dataIndex);
if( item.quantity > 1000 ) color = 0x00FF00;
It's just that easy.
출처 : http://weblogs.macromedia.com/pent/archives/2006/10/datagrid_tip_ro.cfm
출처 : http://www.ihelpers.co.kr/programming/tipntech.php?CMD=view&TYPE=8&KEY=&SC=S&&CC=&PAGE=1&IDX=547
1.데모
2. 소스
MiyaGrid.mxml
<?xml version="1.0" encoding="utf-8"?> <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" xmlns:ns1="*" creationComplete="initApp()" viewSourceURL="srcview/index.html" fontSize="12"> <mx:Script> <![CDATA[ import mx.controls.dataGridClasses.DataGridColumn; import mx.collections.ArrayCollection; import mx.controls.Alert; [Bindable] private var ArrCol:ArrayCollection = new ArrayCollection(); public function initApp():void{ myGrid.dataProvider = ArrCol; } public function onChangeColumn():void{ // Grid init myGrid.columns = []; ArrCol.removeAll(); var arrCol:Array = new Array(); for(var i:uint = 0; i<chgColumn.value;i++){ var col:DataGridColumn = new DataGridColumn("col"+i); var colRender:ClassFactory = new ClassFactory(LabelRenderer); colRender.properties = {headerText:"컬럼"+i}; col.headerRenderer = colRender; col.setStyle("textAlign","right"); arrCol.push(col); } myGrid.columns = arrCol; for(i=0;i<100;i++){ var colval:Object = new Object; for(var j:uint = 0; j<chgColumn.value;j++){ colval["col"+j] = (i+1)*(j+1); } ArrCol.addItem(colval); } } ]]> </mx:Script> <mx:Component id="HeaderLabelRenderer"> <mx:HBox horizontalAlign="left" verticalAlign="middle"> <mx:Label text="" textIndent="3" width="100%" textAlign="left"/> </mx:HBox> </mx:Component> <mx:DataGrid left="10" right="10" top="70" bottom="10" id="myGrid" fontSize="12"/> <mx:HBox left="10" right="10" top="10" bottom="518"> <mx:Form width="100%"> <mx:FormItem label="컬럼수"> <mx:HSlider id="chgColumn" width="236" minimum="5" maximum="10" snapInterval="1" enabled="true" change="onChangeColumn()"/> </mx:FormItem> </mx:Form> </mx:HBox> </mx:Application> |
LabelRenderer.mxml
Grid HeaderText 값을 동적으로 사용하기 위해 headerText 사용하였습니다.
<?xml version="1.0" encoding="utf-8"?> private var _headerText:String; public function initComp():void { |
3. 참고
무한루프
while (param.getSampleCodes().iterator()) {
System.out.println(itr.next());
}
올바른 사용
Iterator<String> itr = param.getSampleCodes().iterator();
while (itr.hasNext()) {
System.out.println(itr.next());
}
Iterator<String> itr = param.getSampleCodes().iterator();
while (itr.hasNext()) {
System.out.println(itr.next());
}
for (String s : param.getSampleCodes())
System.out.println(s);
별것 아니지만 기록으로 남긴다.
1. Java 프로그램을 exe 파일로 만드려면 별도의 프로그램이 필요하다.
나는 그 중에서 JSmooth 를 사용. 일단 다운부터 받자.
JSmooth Download
2. notepad 에 Main-Class: package_name 을 적어서 MANIFEST.MF 로 저장하자.
패키지이름끝은 main()이 들어있는 클래스파일명으로 끝나게.
예) 패키지명 com.project.BBmachine
main()이 들어있는 클래스파일 BeatBox.class
저 줄을 입력하고 마지막에 엔터키를 쳐 개행을 해야한다고 한다.
3. .jar 로 압축하기.
jar cmf manifest.mf BJar.jar com/project/BBmachine/BeatBox
BJar.jar - 만들고자 하는 jar 파일명
com/project.... - 프로그램 디렉토리(상대주소)
4. JSmooth 실행
왼쪽에 있는 Skelector 메뉴 선택 - skeleton selection에서 콘솔 or 윈도우 선택 (자신의 프로그램에 따라)
- skeleton properties 에서 세번째 줄 체크박스 체크
5.
Executable 메뉴 - Executable Binary 에 만들고자 하는 exe 파일명 입력 - Executable Icon 에 원하는
아이콘 이미지 삽입 (아이콘 파일 형식에 따라 삽입이 안되는 경우 있으니 그림이 뜨는지 확인)
6.
Application 메뉴 - Classpath 부터 지정. 오른쪽 추가버튼 클릭하여 아까 만든 .jar 파일 선택
- Main class 에는 ..디렉토리 버튼을 눌러 main() 이 있는 클래스파일 선택
7.
JVM Selection 메뉴 - Minimum JVM Version 에 자신이 사용한 java 버전 입력
8.
톱니바퀴 모양의 아이콘을 누르면 jsmooth 파일이 생김(파일이름 지정해주어야 함)
Done 으로 뜨면 exe 파일이 만들어진것임
(참고사이트)
http://blog.naver.com/easy20/90014252360
http://blog.naver.com/sungback/80019669157
처음으로 요런 포스트를 만들었다. 힘들다. 특히 print screen 이 귀찮은 정도~ 나름 뿌듯 ^^
출처 자바실행 파일 만들기|작성자 욱이천재
The following example shows the differences between a clustered, stacked, 100%, and overlaid Bar chart in Flex 3.
Full code after the jump.
<?xml version="1.0" encoding="utf-8"?> <!-- http://blog.flexexamples.com/2007/10/11/creating-clustered-stacked-overlaid-and-100-bar-charts-in-flex-3/ --> <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="vertical" verticalAlign="middle" backgroundColor="white"> <mx:ApplicationControlBar dock="true"> <mx:Form> <mx:FormItem label="type:"> <mx:ComboBox id="comboBox"> <mx:dataProvider> <mx:Object label="clustered" /> <mx:Object label="stacked" /> <mx:Object label="100%" /> <mx:Object label="overlaid" /> </mx:dataProvider> </mx:ComboBox> </mx:FormItem> <mx:FormItem label="showDataTips:"> <mx:CheckBox id="checkBox1" /> </mx:FormItem> <mx:FormItem label="showAllDataTips:"> <mx:CheckBox id="checkBox2" /> </mx:FormItem> </mx:Form> <mx:Spacer width="100%" /> <mx:Legend dataProvider="{barChart}"/> </mx:ApplicationControlBar> <mx:BarChart id="barChart" type="{comboBox.selectedItem.label}" showDataTips="{checkBox1.selected}" showAllDataTips="{checkBox2.selected}" height="100%" width="100%"> <mx:dataProvider> <mx:Array> <mx:Object name="R Winn" obp=".353" slg=".445" avg=".300" /> <mx:Object name="P Feliz" obp=".290" slg=".418" avg=".253" /> <mx:Object name="O Vizquel" obp=".305" slg=".316" avg=".246" /> <mx:Object name="B Molina" obp=".298" slg=".433" avg=".276" /> <mx:Object name="R Durham" obp=".295" slg=".343" avg=".218" /> </mx:Array> </mx:dataProvider> <mx:verticalAxis> <mx:CategoryAxis categoryField="name"/> </mx:verticalAxis> <mx:series> <mx:BarSeries yField="name" xField="obp" displayName="OBP"/> <mx:BarSeries yField="name" xField="slg" displayName="SLG"/> <mx:BarSeries yField="name" xField="avg" displayName="AVG"/> </mx:series> </mx:BarChart> </mx:Application>
View source is enabled in the following example.