mirror of
https://github.com/UpsilonNumworks/Upsilon.git
synced 2026-01-18 16:27:34 +01:00
[code/python] Fixed the Kandinsky module in Python.
User can draw on the 320*220 drawing screen. Change-Id: I25034b05f21aacc35608358fdb7a4d9924dd22e8
This commit is contained in:
@@ -1,4 +1,5 @@
|
||||
#include "apps_window.h"
|
||||
#include <escher/metric.h>
|
||||
extern "C" {
|
||||
#include <assert.h>
|
||||
}
|
||||
@@ -54,7 +55,7 @@ View * AppsWindow::subviewAtIndex(int index) {
|
||||
}
|
||||
|
||||
void AppsWindow::layoutSubviews() {
|
||||
KDCoordinate titleHeight = m_hideTitleBarView ? 0 : k_titleBarHeight;
|
||||
KDCoordinate titleHeight = m_hideTitleBarView ? 0 : Metric::TitleBarHeight;
|
||||
m_titleBarView.setFrame(KDRect(0, 0, bounds().width(), titleHeight));
|
||||
if (m_contentView != nullptr) {
|
||||
m_contentView->setFrame(KDRect(0, titleHeight, bounds().width(), bounds().height()-titleHeight));
|
||||
|
||||
@@ -15,7 +15,6 @@ public:
|
||||
bool updateAlphaLock();
|
||||
void hideTitleBarView(bool hide);
|
||||
private:
|
||||
constexpr static KDCoordinate k_titleBarHeight = 18;
|
||||
int numberOfSubviews() const override;
|
||||
void layoutSubviews() override;
|
||||
View * subviewAtIndex(int index) override;
|
||||
|
||||
@@ -11,15 +11,31 @@ extern "C" {
|
||||
|
||||
namespace Code {
|
||||
|
||||
|
||||
ConsoleController::ContentView::ContentView(SelectableTableView * selectabletableView) :
|
||||
m_selectableTableView(selectabletableView)
|
||||
{
|
||||
}
|
||||
|
||||
void ConsoleController::ContentView::layoutSubviews() {
|
||||
m_selectableTableView->setFrame(bounds());
|
||||
}
|
||||
|
||||
void ConsoleController::ContentView::markAsDirty() {
|
||||
markRectAsDirty(bounds());
|
||||
}
|
||||
|
||||
ConsoleController::ConsoleController(Responder * parentResponder, ScriptStore * scriptStore) :
|
||||
ViewController(parentResponder),
|
||||
SelectableTableViewDataSource(),
|
||||
TextFieldDelegate(),
|
||||
MicroPython::ExecutionEnvironment(),
|
||||
m_rowHeight(KDText::charSize(k_fontSize).height()),
|
||||
m_selectableTableView(this, this, 0, 1, 0, Metric::CommonRightMargin, 0, Metric::TitleBarExternHorizontalMargin, this, this, true, true, KDColorWhite),
|
||||
m_editCell(this, this),
|
||||
m_pythonHeap(nullptr),
|
||||
m_scriptStore(scriptStore)
|
||||
m_scriptStore(scriptStore),
|
||||
m_view(&m_selectableTableView)
|
||||
{
|
||||
for (int i = 0; i < k_numberOfLineCells; i++) {
|
||||
m_cells[i].setParentResponder(&m_selectableTableView);
|
||||
@@ -254,6 +270,10 @@ void ConsoleController::printText(const char * text, size_t length) {
|
||||
}
|
||||
}
|
||||
|
||||
void ConsoleController::redraw() {
|
||||
m_view.markAsDirty();
|
||||
}
|
||||
|
||||
void ConsoleController::autoImportScriptAtIndex(int index) {
|
||||
const char * importCommand1 = "from ";
|
||||
const char * importCommand2 = " import *";
|
||||
|
||||
@@ -32,7 +32,7 @@ public:
|
||||
void removeExtensionIfAny(char * name);
|
||||
|
||||
// ViewController
|
||||
View * view() override { return &m_selectableTableView; }
|
||||
View * view() override { return &m_view; }
|
||||
void viewWillAppear() override;
|
||||
void didBecomeFirstResponder() override;
|
||||
bool handleEvent(Ion::Events::Event event) override;
|
||||
@@ -57,8 +57,25 @@ public:
|
||||
bool textFieldDidFinishEditing(TextField * textField, const char * text, Ion::Events::Event event) override;
|
||||
bool textFieldDidAbortEditing(TextField * textField, const char * text) override;
|
||||
::Toolbox * toolboxForTextField(TextField * textField) override;
|
||||
|
||||
// MicroPython::ExecutionEnvironment
|
||||
void printText(const char * text, size_t length) override;
|
||||
void redraw() override;
|
||||
|
||||
// ConsoleController::ContentView
|
||||
class ContentView : public View {
|
||||
public:
|
||||
ContentView(SelectableTableView * selectabletableView);
|
||||
void markAsDirty();
|
||||
private:
|
||||
int numberOfSubviews() const override { return 1; }
|
||||
View * subviewAtIndex(int index) override {
|
||||
assert(index == 0);
|
||||
return m_selectableTableView;
|
||||
}
|
||||
void layoutSubviews() override;
|
||||
SelectableTableView * m_selectableTableView;
|
||||
};
|
||||
|
||||
private:
|
||||
static constexpr int LineCellType = 0;
|
||||
@@ -85,6 +102,7 @@ private:
|
||||
* happens, or when m_outputAccumulationBuffer is full, we create a new
|
||||
* ConsoleLine in the ConsoleStore and empty m_outputAccumulationBuffer. */
|
||||
ScriptStore * m_scriptStore;
|
||||
ContentView m_view;
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
@@ -12,6 +12,7 @@ ScriptStore::ScriptStore() :
|
||||
{
|
||||
addScriptFromTemplate(ScriptTemplate::Factorial());
|
||||
addScriptFromTemplate(ScriptTemplate::Fibonacci());
|
||||
addScriptFromTemplate(ScriptTemplate::Mandelbrot());
|
||||
}
|
||||
|
||||
const Script ScriptStore::scriptAtIndex(int index, EditableZone zone) {
|
||||
|
||||
@@ -31,9 +31,9 @@ constexpr ScriptTemplate mandelbrotScriptTemplate("mandelbrot.py", R"(# This scr
|
||||
# N_iteration: degree of precision
|
||||
import kandinsky
|
||||
N_iteration = 10
|
||||
def drawMandelbrot():
|
||||
def drawMandlebrot():
|
||||
for x in range(320):
|
||||
for y in range(240):
|
||||
for y in range(222):
|
||||
# Compute the mandelbrot sequence for the point c = (c_r, c_i) with start value z = (z_r, z_i)
|
||||
z_r = 0
|
||||
z_i = 0
|
||||
|
||||
@@ -11,6 +11,7 @@ public:
|
||||
constexpr static KDCoordinate CommonBottomMargin = 15;
|
||||
constexpr static KDCoordinate HistoryHorizontalMargin = 10;
|
||||
constexpr static KDCoordinate TitleBarExternHorizontalMargin = 5;
|
||||
constexpr static KDCoordinate TitleBarHeight = 18;
|
||||
constexpr static KDCoordinate ParameterCellHeight = 35;
|
||||
constexpr static KDCoordinate ModalTopMargin = 5;
|
||||
constexpr static KDCoordinate ModalBottomMargin = 18;
|
||||
|
||||
@@ -21,4 +21,3 @@ const mp_obj_module_t kandinsky_module = {
|
||||
.base = { &mp_type_module },
|
||||
.globals = (mp_obj_dict_t*)&kandinsky_module_globals,
|
||||
};
|
||||
|
||||
|
||||
@@ -1,7 +1,9 @@
|
||||
extern "C" {
|
||||
#include "modkandinsky.h"
|
||||
}
|
||||
#include <escher/metric.h>
|
||||
#include <kandinsky.h>
|
||||
#include "port.h"
|
||||
|
||||
mp_obj_t kandinsky_color(mp_obj_t red, mp_obj_t green, mp_obj_t blue) {
|
||||
return
|
||||
@@ -16,22 +18,25 @@ mp_obj_t kandinsky_color(mp_obj_t red, mp_obj_t green, mp_obj_t blue) {
|
||||
|
||||
mp_obj_t kandinsky_get_pixel(mp_obj_t x, mp_obj_t y) {
|
||||
KDColor c = KDIonContext::sharedContext()->getPixel(
|
||||
KDPoint(mp_obj_get_int(x), mp_obj_get_int(y))
|
||||
KDPoint(mp_obj_get_int(x), mp_obj_get_int(y) + Metric::TitleBarHeight)
|
||||
);
|
||||
return MP_OBJ_NEW_SMALL_INT(c);
|
||||
}
|
||||
mp_obj_t kandinsky_set_pixel(mp_obj_t x, mp_obj_t y, mp_obj_t color) {
|
||||
KDIonContext::sharedContext()->setPixel(
|
||||
KDPoint(mp_obj_get_int(x), mp_obj_get_int(y)),
|
||||
KDPoint(mp_obj_get_int(x), mp_obj_get_int(y) + Metric::TitleBarHeight),
|
||||
KDColor::RGB16(mp_obj_get_int(color))
|
||||
);
|
||||
MicroPython::ExecutionEnvironment::currentExecutionEnvironment()->didModifyFramebuffer();
|
||||
return mp_const_none;
|
||||
}
|
||||
|
||||
mp_obj_t kandinsky_draw_string(mp_obj_t text, mp_obj_t x, mp_obj_t y) {
|
||||
KDIonContext::sharedContext()->drawString(
|
||||
mp_obj_str_get_str(text),
|
||||
KDPoint(mp_obj_get_int(x), mp_obj_get_int(y))
|
||||
KDPoint(mp_obj_get_int(x), mp_obj_get_int(y) + Metric::TitleBarHeight)
|
||||
);
|
||||
MicroPython::ExecutionEnvironment::currentExecutionEnvironment()->didModifyFramebuffer();
|
||||
return mp_const_none;
|
||||
}
|
||||
|
||||
|
||||
@@ -1,3 +1,10 @@
|
||||
#include <apps/i18n.h>
|
||||
#include <escher/metric.h>
|
||||
#include <ion/display.h>
|
||||
#include <ion/events.h>
|
||||
#include <ion/keyboard.h>
|
||||
#include "port.h"
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
@@ -16,19 +23,31 @@ extern "C" {
|
||||
#include "py/stackctrl.h"
|
||||
}
|
||||
|
||||
#include <apps/i18n.h>
|
||||
#include <ion/keyboard.h>
|
||||
#include "port.h"
|
||||
|
||||
static char * python_stack_top = NULL;
|
||||
|
||||
static MicroPython::ScriptProvider * sScriptProvider = nullptr;
|
||||
static MicroPython::ExecutionEnvironment * sCurrentExecutionEnvironment = nullptr;
|
||||
|
||||
MicroPython::ExecutionEnvironment::ExecutionEnvironment() :
|
||||
m_framebufferHasBeenModified(false)
|
||||
{
|
||||
}
|
||||
|
||||
MicroPython::ExecutionEnvironment * MicroPython::ExecutionEnvironment::currentExecutionEnvironment() {
|
||||
return sCurrentExecutionEnvironment;
|
||||
}
|
||||
|
||||
void MicroPython::ExecutionEnvironment::didModifyFramebuffer() {
|
||||
m_framebufferHasBeenModified = true;
|
||||
}
|
||||
|
||||
void MicroPython::ExecutionEnvironment::runCode(const char * str) {
|
||||
assert(sCurrentExecutionEnvironment == nullptr);
|
||||
sCurrentExecutionEnvironment = this;
|
||||
|
||||
KDIonContext::sharedContext()->setOrigin(KDPointZero);
|
||||
KDIonContext::sharedContext()->setClippingRect(KDRect(0, Metric::TitleBarHeight, Ion::Display::Width, Ion::Display::Height - Metric::TitleBarHeight));
|
||||
|
||||
nlr_buf_t nlr;
|
||||
if (nlr_push(&nlr) == 0) {
|
||||
mp_lexer_t *lex = mp_lexer_new_from_str_len(0, str, strlen(str), false);
|
||||
@@ -74,6 +93,15 @@ void MicroPython::ExecutionEnvironment::runCode(const char * str) {
|
||||
/* End of mp_obj_print_exception. */
|
||||
}
|
||||
|
||||
while (m_framebufferHasBeenModified) {
|
||||
int timeout = 3000;
|
||||
Ion::Events::Event event = Ion::Events::getEvent(&timeout);
|
||||
if (event == Ion::Events::OK || event == Ion::Events::Back) {
|
||||
m_framebufferHasBeenModified = false;
|
||||
redraw();
|
||||
}
|
||||
}
|
||||
|
||||
assert(sCurrentExecutionEnvironment == this);
|
||||
sCurrentExecutionEnvironment = nullptr;
|
||||
}
|
||||
|
||||
@@ -10,9 +10,16 @@ public:
|
||||
|
||||
class ExecutionEnvironment {
|
||||
public:
|
||||
ExecutionEnvironment();
|
||||
static ExecutionEnvironment * currentExecutionEnvironment();
|
||||
void didModifyFramebuffer();
|
||||
void runCode(const char * );
|
||||
virtual void printText(const char * text, size_t length) {
|
||||
}
|
||||
virtual void redraw() {
|
||||
}
|
||||
private:
|
||||
bool m_framebufferHasBeenModified;
|
||||
};
|
||||
|
||||
void init(void * heapStart, void * heapEnd);
|
||||
|
||||
Reference in New Issue
Block a user