A pixel art painter geared specifically at NES pixel art. Includes export for .chr binary file as well as palette and namespace data.
Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

264 lines
14KB

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
  6. <title>NES Painter</title>
  7. <link href="https://fonts.googleapis.com/css?family=Roboto" rel="stylesheet">
  8. <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.6.3/css/all.css" integrity="sha384-UHRtZLI+pbxtHCWp1t77Bi1L4ZtiqrqD80Kn4Z8NTSRyMA2Fd33n5dQ8lWUE00s/" crossorigin="anonymous">
  9. <link rel="stylesheet" href="https://unpkg.com/purecss@1.0.0/build/pure-min.css" integrity="sha384-nn4HPE8lTHyVtfCBi5yW9d20FjT8BJwUXyWZT9InLYax14RDjBj46LmSztkmNP9w" crossorigin="anonymous">
  10. <link rel="stylesheet" href="app/css/nespaint.css">
  11. </head>
  12. <body>
  13. <div id="Welcome" class="modal">
  14. <div class="modal-content">
  15. Welcome to the modal!
  16. </div>
  17. </div>
  18. <div class="header">
  19. <div class="home-menu pure-menu pure-menu-horizontal">
  20. <a class="pure-menu-heading" href="">
  21. <span class="color-NES-06">NES </span>
  22. <span class="color-NES-random">P</span><span class="color-NES-random">a</span><span class="color-NES-random">i</span><span class="color-NES-random">n</span><span class="color-NES-random">t</span>
  23. </a>
  24. </div>
  25. </div>
  26. <div class="content-wrapper">
  27. <div class="pure-g">
  28. <div class="pure-u-1-8 simple-padding">
  29. <div class="pure-button-group" role="group" aria-label="...">
  30. <button emit="modal-open" emit-args='{"id":"Welcome"}' class="pure-button">
  31. <i class="fa fa-brush"></i>
  32. </button>
  33. <button emit="modal-open" emit-args='{"id":"Welcome"}' class="pure-button">
  34. <i class="fa fa-eraser"></i>
  35. </button>
  36. <button class="pure-button pure-button-active">
  37. <i class="fa fa-eye-dropper"></i>
  38. </button>
  39. </div>
  40. </div>
  41. <div class="pure-u-2-3">
  42. <div class="pure-g">
  43. <div class="pure-u-1 simple-padding">
  44. <canvas id="painter" width:"128" height:"256"></canvas>
  45. </div>
  46. </div>
  47. <div class="pure-g">
  48. <div class="pure-u-1-2">
  49. <div class="simple-padding">
  50. NES System Palette
  51. </div>
  52. <div class="NES-palette simple-padding">
  53. <div class="pure-g">
  54. <div class="pure-u-1-4">
  55. <div class="pure-g">
  56. <div class="pure-u-1-4"><button class="pure-button" nesidx="00">00</button></div>
  57. <div class="pure-u-1-4"><button class="pure-button" nesidx="01">01</button></div>
  58. <div class="pure-u-1-4"><button class="pure-button" nesidx="02">02</button></div>
  59. <div class="pure-u-1-4"><button class="pure-button" nesidx="03">03</button></div>
  60. </div>
  61. </div>
  62. <div class="pure-u-1-4">
  63. <div class="pure-g">
  64. <div class="pure-u-1-4"><button class="pure-button" nesidx="04">04</button></div>
  65. <div class="pure-u-1-4"><button class="pure-button" nesidx="05">05</button></div>
  66. <div class="pure-u-1-4"><button class="pure-button" nesidx="06">06</button></div>
  67. <div class="pure-u-1-4"><button class="pure-button" nesidx="07">07</button></div>
  68. </div>
  69. </div>
  70. <div class="pure-u-1-4">
  71. <div class="pure-g">
  72. <div class="pure-u-1-4"><button class="pure-button" nesidx="08">08</button></div>
  73. <div class="pure-u-1-4"><button class="pure-button" nesidx="09">09</button></div>
  74. <div class="pure-u-1-4"><button class="pure-button" nesidx="0A">0A</button></div>
  75. <div class="pure-u-1-4"><button class="pure-button" nesidx="0B">0B</button></div>
  76. </div>
  77. </div>
  78. <div class="pure-u-1-4">
  79. <div class="pure-g">
  80. <div class="pure-u-1-4"><button class="pure-button" nesidx="0C">0C</button></div>
  81. <div class="pure-u-1-4"><button class="pure-button" nesidx="0D">0D</button></div>
  82. <div class="pure-u-1-4"><button class="pure-button" nesidx="0E">0E</button></div>
  83. <div class="pure-u-1-4"><button class="pure-button" nesidx="0F">0F</button></div>
  84. </div>
  85. </div>
  86. </div>
  87. <div class="pure-g">
  88. <div class="pure-u-1-4">
  89. <div class="pure-g">
  90. <div class="pure-u-1-4"><button class="pure-button" nesidx="10">10</button></div>
  91. <div class="pure-u-1-4"><button class="pure-button" nesidx="11">11</button></div>
  92. <div class="pure-u-1-4"><button class="pure-button" nesidx="12">12</button></div>
  93. <div class="pure-u-1-4"><button class="pure-button" nesidx="13">13</button></div>
  94. </div>
  95. </div>
  96. <div class="pure-u-1-4">
  97. <div class="pure-g">
  98. <div class="pure-u-1-4"><button class="pure-button" nesidx="14">14</button></div>
  99. <div class="pure-u-1-4"><button class="pure-button" nesidx="15">15</button></div>
  100. <div class="pure-u-1-4"><button class="pure-button" nesidx="16">16</button></div>
  101. <div class="pure-u-1-4"><button class="pure-button" nesidx="17">17</button></div>
  102. </div>
  103. </div>
  104. <div class="pure-u-1-4">
  105. <div class="pure-g">
  106. <div class="pure-u-1-4"><button class="pure-button" nesidx="18">18</button></div>
  107. <div class="pure-u-1-4"><button class="pure-button" nesidx="19">19</button></div>
  108. <div class="pure-u-1-4"><button class="pure-button" nesidx="1A">1A</button></div>
  109. <div class="pure-u-1-4"><button class="pure-button" nesidx="1B">1B</button></div>
  110. </div>
  111. </div>
  112. <div class="pure-u-1-4">
  113. <div class="pure-g">
  114. <div class="pure-u-1-4"><button class="pure-button" nesidx="1C">1C</button></div>
  115. <div class="pure-u-1-4"><button class="pure-button" nesidx="1D">1D</button></div>
  116. <div class="pure-u-1-4"><button class="pure-button" nesidx="1E">1E</button></div>
  117. <div class="pure-u-1-4"><button class="pure-button" nesidx="1F">1F</button></div>
  118. </div>
  119. </div>
  120. </div>
  121. <div class="pure-g">
  122. <div class="pure-u-1-4">
  123. <div class="pure-g">
  124. <div class="pure-u-1-4"><button class="pure-button" nesidx="20">20</button></div>
  125. <div class="pure-u-1-4"><button class="pure-button" nesidx="21">21</button></div>
  126. <div class="pure-u-1-4"><button class="pure-button" nesidx="22">22</button></div>
  127. <div class="pure-u-1-4"><button class="pure-button" nesidx="23">23</button></div>
  128. </div>
  129. </div>
  130. <div class="pure-u-1-4">
  131. <div class="pure-g">
  132. <div class="pure-u-1-4"><button class="pure-button" nesidx="24">24</button></div>
  133. <div class="pure-u-1-4"><button class="pure-button" nesidx="25">25</button></div>
  134. <div class="pure-u-1-4"><button class="pure-button" nesidx="26">26</button></div>
  135. <div class="pure-u-1-4"><button class="pure-button" nesidx="27">27</button></div>
  136. </div>
  137. </div>
  138. <div class="pure-u-1-4">
  139. <div class="pure-g">
  140. <div class="pure-u-1-4"><button class="pure-button" nesidx="28">28</button></div>
  141. <div class="pure-u-1-4"><button class="pure-button" nesidx="29">29</button></div>
  142. <div class="pure-u-1-4"><button class="pure-button" nesidx="2A">2A</button></div>
  143. <div class="pure-u-1-4"><button class="pure-button" nesidx="2B">2B</button></div>
  144. </div>
  145. </div>
  146. <div class="pure-u-1-4">
  147. <div class="pure-g">
  148. <div class="pure-u-1-4"><button class="pure-button" nesidx="2C">2C</button></div>
  149. <div class="pure-u-1-4"><button class="pure-button" nesidx="2D">2D</button></div>
  150. <div class="pure-u-1-4"><button class="pure-button" nesidx="2E">2E</button></div>
  151. <div class="pure-u-1-4"><button class="pure-button" nesidx="2F">2F</button></div>
  152. </div>
  153. </div>
  154. </div>
  155. <div class="pure-g">
  156. <div class="pure-u-1-4">
  157. <div class="pure-g">
  158. <div class="pure-u-1-4"><button class="pure-button" nesidx="30">30</button></div>
  159. <div class="pure-u-1-4"><button class="pure-button" nesidx="31">31</button></div>
  160. <div class="pure-u-1-4"><button class="pure-button" nesidx="32">32</button></div>
  161. <div class="pure-u-1-4"><button class="pure-button" nesidx="33">33</button></div>
  162. </div>
  163. </div>
  164. <div class="pure-u-1-4">
  165. <div class="pure-g">
  166. <div class="pure-u-1-4"><button class="pure-button" nesidx="34">34</button></div>
  167. <div class="pure-u-1-4"><button class="pure-button" nesidx="35">35</button></div>
  168. <div class="pure-u-1-4"><button class="pure-button" nesidx="36">36</button></div>
  169. <div class="pure-u-1-4"><button class="pure-button" nesidx="37">37</button></div>
  170. </div>
  171. </div>
  172. <div class="pure-u-1-4">
  173. <div class="pure-g">
  174. <div class="pure-u-1-4"><button class="pure-button" nesidx="38">38</button></div>
  175. <div class="pure-u-1-4"><button class="pure-button" nesidx="39">39</button></div>
  176. <div class="pure-u-1-4"><button class="pure-button" nesidx="3A">3A</button></div>
  177. <div class="pure-u-1-4"><button class="pure-button" nesidx="3B">3B</button></div>
  178. </div>
  179. </div>
  180. <div class="pure-u-1-4">
  181. <div class="pure-g">
  182. <div class="pure-u-1-4"><button class="pure-button" nesidx="3C">3C</button></div>
  183. <div class="pure-u-1-4"><button class="pure-button" nesidx="3D">3D</button></div>
  184. <div class="pure-u-1-4"><button class="pure-button" nesidx="3E">3E</button></div>
  185. <div class="pure-u-1-4"><button class="pure-button" nesidx="3F">3F</button></div>
  186. </div>
  187. </div>
  188. </div>
  189. </div>
  190. </div>
  191. <div class="pure-u-1-2">
  192. <div class-"simple-padding">
  193. Drawing Palettes
  194. </div>
  195. <div class="pure-g">
  196. <div class="pure-u-1-2">
  197. <div class="simple-padding">
  198. Palette 1
  199. </div>
  200. <div class="simple-padding">
  201. <div class="pure-button-group" role="group">
  202. <button class="pure-button" cidx="0" pidx="0">0</button>
  203. <button class="pure-button" cidx="1" pidx="0">1</button>
  204. <button class="pure-button" cidx="2" pidx="0">2</button>
  205. <button class="pure-button" cidx="3" pidx="0">3</button>
  206. </div>
  207. </div>
  208. </div>
  209. <div class="pure-u-1-2">
  210. <div class="simple-padding">
  211. Palette 2
  212. </div>
  213. <div class="simple-padding">
  214. <div class="pure-button-group" role="group">
  215. <button class="pure-button" cidx="0" pidx="1">0</button>
  216. <button class="pure-button" cidx="1" pidx="1">1</button>
  217. <button class="pure-button" cidx="2" pidx="1">2</button>
  218. <button class="pure-button" cidx="3" pidx="1">3</button>
  219. </div>
  220. </div>
  221. </div>
  222. </div>
  223. <div class="pure-g">
  224. <div class="pure-u-1-2">
  225. <div class="simple-padding">
  226. Palette 3
  227. </div>
  228. <div class="simple-padding">
  229. <div class="pure-button-group" role="group">
  230. <button class="pure-button" cidx="0" pidx="2">0</button>
  231. <button class="pure-button" cidx="1" pidx="2">1</button>
  232. <button class="pure-button" cidx="2" pidx="2">2</button>
  233. <button class="pure-button" cidx="3" pidx="2">3</button>
  234. </div>
  235. </div>
  236. </div>
  237. <div class="pure-u-1-2">
  238. <div class="simple-padding">
  239. Palette 4
  240. </div>
  241. <div class="simple-padding">
  242. <div class="pure-button-group" role="group">
  243. <button class="pure-button" cidx="0" pidx="3">0</button>
  244. <button class="pure-button" cidx="1" pidx="3">1</button>
  245. <button class="pure-button" cidx="2" pidx="3">2</button>
  246. <button class="pure-button" cidx="3" pidx="3">3</button>
  247. </div>
  248. </div>
  249. </div>
  250. </div>
  251. </div>
  252. </div>
  253. </div>
  254. </div>
  255. </div>
  256. </body>
  257. <script src="app/js/main.js" type="module"></script>
  258. </html>