Mercurial > vba-clojure
changeset 522:5596cd4a3fc6
added RAM display.
author | Robert McIntyre <rlm@mit.edu> |
---|---|
date | Sat, 23 Jun 2012 19:12:26 -0500 (2012-06-24) |
parents | bad7b7430245 |
children | d00096b6bf17 |
files | clojure/com/aurellem/gb/gb_driver.clj clojure/com/aurellem/run/image.clj clojure/com/aurellem/run/ram_display.clj images/RAM-test.png java/src/com/aurellem/gb/Gb.java src/clojure/clojure.cpp src/gb/GB.h todo.org |
diffstat | 8 files changed, 94 insertions(+), 23 deletions(-) [+] |
line wrap: on
line diff
1.1 --- a/clojure/com/aurellem/gb/gb_driver.clj Sat Jun 23 17:45:38 2012 -0500 1.2 +++ b/clojure/com/aurellem/gb/gb_driver.clj Sat Jun 23 19:12:26 2012 -0500 1.3 @@ -154,6 +154,13 @@ 1.4 (set-state! state) 1.5 (dorun (map (fn [move] (step @current-state move)) moves)) 1.6 [(concat prev moves) @current-state])) 1.7 + 1.8 +(defn accurate-memory 1.9 + ([^SaveState state address] 1.10 + (set-state! state) 1.11 + (Gb/readMemory address)) 1.12 + ([address] 1.13 + (accurate-memory @current-state address))) 1.14 1.15 ;;;;;;;;;;; 1.16 1.17 @@ -166,9 +173,6 @@ 1.18 ([^File target] 1.19 (write-png! @current-state target))) 1.20 1.21 - 1.22 - 1.23 - 1.24 ;;;;;;;;;;;;;;; CPU data 1.25 1.26 (defn cpu-data [size arr-fn] 1.27 @@ -294,6 +298,4 @@ 1.28 (defn rgb->gb-rb [[r g b :as color]] 1.29 (let [store (int-array 3)] 1.30 (Gb/translateRGB (int-array color) store) 1.31 - (vec store))) 1.32 - 1.33 - 1.34 + (vec store))) 1.35 \ No newline at end of file
2.1 --- a/clojure/com/aurellem/run/image.clj Sat Jun 23 17:45:38 2012 -0500 2.2 +++ b/clojure/com/aurellem/run/image.clj Sat Jun 23 19:12:26 2012 -0500 2.3 @@ -6,6 +6,7 @@ 2.4 bootstrap-0 bootstrap-1)) 2.5 (:require clojure.string) 2.6 (:import [com.aurellem.gb.gb_driver SaveState]) 2.7 + (:import java.awt.image.BufferedImage) 2.8 (:import java.io.File)) 2.9 2.10 ;; want to display an image onto the screen. 2.11 @@ -149,7 +150,7 @@ 2.12 (display-one-color @current-state [r g b]))) 2.13 2.14 ;;(require 'cortex.sense) 2.15 -(import java.awt.image.BufferedImage) 2.16 + 2.17 2.18 ;; (defn show-screenshot [] 2.19 ;; (let [im (BufferedImage. 160 144 BufferedImage/TYPE_INT_RGB) 2.20 @@ -203,6 +204,15 @@ 2.21 (import '(javax.imageio ImageWriteParam IIOImage ImageIO)) 2.22 2.23 2.24 +(defn write-image! [^BufferedImage image ^File target] 2.25 + (doto 2.26 + (.next (ImageIO/getImageWritersByFormatName "png")) 2.27 + (.setOutput (FileImageOutputStream. target)) 2.28 + (.write (IIOImage. image nil nil)) 2.29 + (.dispose)) 2.30 + image) 2.31 + 2.32 + 2.33 (defn gen-gb-color-image! [] 2.34 (let [im (BufferedImage. 68 69 BufferedImage/TYPE_INT_RGB) 2.35 pix (vec 2.36 @@ -242,13 +252,9 @@ 2.37 b)] 2.38 (.setRGB im x y rgb)))) 2.39 ;;(view im) 2.40 - (doto 2.41 - (.next (ImageIO/getImageWritersByFormatName "png")) 2.42 - (.setOutput (FileImageOutputStream. target)) 2.43 - (.write (IIOImage. im nil nil)) 2.44 - (.dispose)) 2.45 - im)) 2.46 - 2.47 + (write-image! im target))) 2.48 + 2.49 + 2.50 (defn gen-gb-color-image*! [] 2.51 (let [im (BufferedImage. 213 213 BufferedImage/TYPE_INT_RGB) 2.52 squares 2.53 @@ -274,12 +280,7 @@ 2.54 (+ 3 (* 35 (int (/ s-index 6))) y) 2.55 rgb)))))) 2.56 ;;(view im) 2.57 - (doto 2.58 - (.next (ImageIO/getImageWritersByFormatName "png")) 2.59 - (.setOutput (FileImageOutputStream. target)) 2.60 - (.write (IIOImage. im nil nil)) 2.61 - (.dispose)) 2.62 - im)) 2.63 + (write-image! im target))) 2.64 2.65 (defn gen-gimp-palette! [] 2.66 (let [target 2.67 @@ -670,9 +671,10 @@ 2.68 (concat A B C D))) 2.69 2.70 (defn display-image [#^BufferedImage image] 2.71 - (let [kernel-address 0xB000] 2.72 + (let [kernel-address 0xB500] 2.73 (-> (tick (tick (tick (mid-game)))) 2.74 (set-memory-range 2.75 kernel-address 2.76 (display-image-kernel kernel-address image)) 2.77 (PC! kernel-address)))) 2.78 +
3.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 3.2 +++ b/clojure/com/aurellem/run/ram_display.clj Sat Jun 23 19:12:26 2012 -0500 3.3 @@ -0,0 +1,53 @@ 3.4 +(ns com.aurellem.run.ram-display 3.5 + (:use (com.aurellem.gb saves gb-driver util constants 3.6 + items vbm characters money 3.7 + rlm-assembly)) 3.8 + (:use (com.aurellem.run image util music title save-corruption 3.9 + bootstrap-0 bootstrap-1)) 3.10 + (:require clojure.string) 3.11 + (:import [com.aurellem.gb.gb_driver SaveState]) 3.12 + 3.13 + (:import java.awt.image.BufferedImage) 3.14 + (:import java.io.File)) 3.15 + 3.16 +(defn accurate-memory-range 3.17 + ([^SaveState state start end] 3.18 + (map accurate-memory (range start end))) 3.19 + ([start end] 3.20 + (accurate-memory-range @current-state start end))) 3.21 + 3.22 +(def video-ram-start 0x8000) 3.23 + 3.24 +(def GB-memory-end 0x10000) 3.25 + 3.26 +(defn ram-image 3.27 + ([^SaveState state] 3.28 + (let [width 128 3.29 + height 256 3.30 + image (BufferedImage. width height 3.31 + BufferedImage/TYPE_INT_RGB) 3.32 + data (vec 3.33 + (accurate-memory-range 3.34 + state video-ram-start GB-memory-end))] 3.35 + (dorun 3.36 + (map 3.37 + (fn [index] 3.38 + (let [gray (data index)] 3.39 + (.setRGB image (rem index width) 3.40 + (int (/ index width)) 3.41 + (+ 3.42 + (bit-shift-left gray 16) 3.43 + (bit-shift-left gray 8) 3.44 + gray)))) 3.45 + (range (count data)))) 3.46 + image)) 3.47 + ([] (ram-image @current-state))) 3.48 + 3.49 +(defn write-ram-image! 3.50 + ([^SaveState state ^File target] 3.51 + (write-image! (ram-image state) target)) 3.52 + ([^File target] 3.53 + (write-ram-image! @current-state target))) 3.54 + 3.55 +(def test-ram-image 3.56 + (File. "/home/r/proj/vba-clojure/images/RAM-test.png"))
4.1 Binary file images/RAM-test.png has changed
5.1 --- a/java/src/com/aurellem/gb/Gb.java Sat Jun 23 17:45:38 2012 -0500 5.2 +++ b/java/src/com/aurellem/gb/Gb.java Sat Jun 23 19:12:26 2012 -0500 5.3 @@ -129,4 +129,5 @@ 5.4 5.5 public static native void nwritePNG(String filename); 5.6 5.7 + public static native int readMemory(int address); 5.8 }
6.1 --- a/src/clojure/clojure.cpp Sat Jun 23 17:45:38 2012 -0500 6.2 +++ b/src/clojure/clojure.cpp Sat Jun 23 19:12:26 2012 -0500 6.3 @@ -2,6 +2,7 @@ 6.4 #include "../sdl/Drive.h" 6.5 #include "../gb/GB.h" 6.6 6.7 + 6.8 #include <string.h> 6.9 6.10 #define UNUSED(x) (void)(x) 6.11 @@ -336,3 +337,13 @@ 6.12 } 6.13 6.14 6.15 + 6.16 +/* 6.17 + * Class: com_aurellem_gb_Gb 6.18 + * Method: readMemory 6.19 + * Signature: (I)I 6.20 + */ 6.21 +JNIEXPORT jint JNICALL Java_com_aurellem_gb_Gb_readMemory 6.22 +(JNIEnv *env, jclass clazz, jint address){ 6.23 + return (jint) gbReadMemory((u16) address); 6.24 +}
7.1 --- a/src/gb/GB.h Sat Jun 23 17:45:38 2012 -0500 7.2 +++ b/src/gb/GB.h Sat Jun 23 19:12:26 2012 -0500 7.3 @@ -63,6 +63,8 @@ 7.4 7.5 extern long gbWriteMemSaveStatePos(char *, int); 7.6 7.7 +extern u8 gbReadMemory(u16 address); 7.8 + 7.9 extern struct EmulatedSystem GBSystem; 7.10 extern struct EmulatedSystemCounters &GBSystemCounters; 7.11
8.1 --- a/todo.org Sat Jun 23 17:45:38 2012 -0500 8.2 +++ b/todo.org Sat Jun 23 19:12:26 2012 -0500 8.3 @@ -1,5 +1,5 @@ 8.4 -* vba-clojure [0/7] 8.5 - - [ ] create ram display 8.6 +* vba-clojure [1/7] 8.7 + - [X] create ram display 8.8 - [ ] derpy hack 8.9 - [ ] sound recording 8.10 - [ ] fix unnecessary pauses before take-over