Skip to content

Commit

Permalink
Merge pull request #92 from bemusic/display-test
Browse files Browse the repository at this point in the history
Note area display
  • Loading branch information
dtinth committed Feb 12, 2015
2 parents cefe024 + 340fe54 commit ed0b72f
Show file tree
Hide file tree
Showing 9 changed files with 282 additions and 223 deletions.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,7 @@
"audio-context": "^0.1.0",
"bluebird": "^2.9.6",
"bms": "^0.2.0",
"chance": "^0.7.3",
"co": "^4.3.1",
"debug": "^2.1.1",
"jquery": "^2.1.3",
Expand Down
Binary file modified public/skins/default/Note/DX.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
370 changes: 184 additions & 186 deletions public/skins/default/skin.xml

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion public/skins/default/skin_data.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ styles:

mode:
iidx_l:
- { style: 'scratch', channel: 'sc' }
- { style: 'scratch', channel: 'SC' }
- { style: 'white', channel: '1' }
- { style: 'blue', channel: '2' }
- { style: 'white', channel: '3' }
Expand Down
11 changes: 5 additions & 6 deletions public/skins/default/skin_template.jade
Original file line number Diff line number Diff line change
Expand Up @@ -12,17 +12,17 @@ skin(width='1280' height='720')
// body
sprite(image='Note/DX.png'
frame=(cur.width + 'x64+' + cur.x + '+' + (22 + add))
x=(x) y='y+4' width=(cur.width) height='height'
x=(x) y='y+4-12' width=(cur.width) height='height'
visible=visible)
// tail
sprite(image='Note/DX.png'
frame=(cur.width + 'x8+' + cur.x + '+' + (104 + add))
x=(x) y='y+height+4'
x=(x) y='y+height+4-12'
visible=visible)
// head
sprite(image='Note/DX.png'
frame=(cur.width + 'x8+' + cur.x + '+' + (12 + add))
x=(x) y='y'
x=(x) y='y-12'
visible=visible)

mixin notes(columns)
Expand All @@ -32,7 +32,7 @@ skin(width='1280' height='720')
- var ch = column.channel
object(key='note_' + ch)
sprite(image='Note/DX.png' frame=(cur.width + 'x12+' + cur.x + '+0')
x=(x) y='y')
x=(x) y='y - 12')
object(key='longnote_' + ch)
+longnote(x, cur, 0, '!active && !missed')
+longnote(x, cur, 100, '!!active && !missed')
Expand All @@ -50,8 +50,7 @@ skin(width='1280' height='720')
sprite(image='NoteArea/Flash.png' x='1' y='476' blend='screen'
alpha='1 - (t % 0.4) / 0.4')
group(x='1' mask='283x550+1+0')
group(y='(t * 500 % 1500) - 500')
+notes(mode.iidx_l)
+notes(mode.iidx_l)

// info panel
sprite(image='InfoPanel/Background.png' y='616')
Expand Down
76 changes: 49 additions & 27 deletions src/app/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,46 +4,44 @@ import * as Scintillator from 'bemuse/scintillator'

import co from 'co'
import $ from 'jquery'
import Chance from 'chance'

import NoteArea from 'bemuse/game/note-area'

export function main() {
co(function*() {
let skin = yield Scintillator.load('/skins/default/skin.xml')
let context = new Scintillator.Context(skin)

let notes = generateRandomNotes()
let area = new NoteArea(notes)

let data = { }
let columns = ['SC', '1', '2', '3', '4', '5', '6', '7']

function updateNotes() {
let p = data.t * 180 / 60
let entities = area.getVisibleNotes(p, p + (5 / 3), 550)
for (let column of columns) {
data[`note_${column}`] = entities.filter(entity =>
!entity.height && entity.column === column)
data[`longnote_${column}`] = entities.filter(entity =>
entity.height && entity.column === column)
.map(entity => Object.assign({ }, entity, {
active: entity.y + entity.height > 550
}))
}
}

data['note_sc'] = [ { key: 1, y: 10 }, { key: 2, y: 160 } ]
data['note_1'] = [ { key: 1, y: 20 }, { key: 2, y: 150 } ]
data['note_2'] = [ { key: 1, y: 30 }, { key: 2, y: 140 } ]
data['note_3'] = [ { key: 1, y: 40 }, { key: 2, y: 130 } ]
data['note_4'] = [ { key: 1, y: 50 }, { key: 2, y: 120 } ]
data['note_5'] = [ { key: 1, y: 60 }, { key: 2, y: 110 } ]
data['note_6'] = [ { key: 1, y: 70 }, { key: 2, y: 90 } ]
data['note_7'] = [ { key: 1, y: 80 } ]

data['longnote_sc'] = [ { key: 1, active: false, y: 210, height: 0 },
{ key: 3, active: true, y: 40, height: 100,
missed: true, }, ]
data['longnote_1'] = [ { key: 1, active: false, y: 220, height: 10 } ]
data['longnote_2'] = [ { key: 1, active: false, y: 230, height: 20 } ]
data['longnote_3'] = [ { key: 1, active: false, y: 240, height: 40,
missed: true, } ]
data['longnote_4'] = [ { key: 1, active: false, y: 250, height: 60 } ]
data['longnote_5'] = [ { key: 1, active: false, y: 260, height: 80 } ]
data['longnote_6'] = [ { key: 1, active: false, y: 270, height: 70,
missed: true, } ]
data['longnote_7'] = [ { key: 1, active: false, y: 280, height: 60 } ]

for (let i of ['longnote_sc', 'longnote_1', 'longnote_2', 'longnote_3',
'longnote_4', 'longnote_5', 'longnote_6', 'longnote_7', ]) {
let y = data[i][0].y + data[i][0].height + 50
let height = 450 - y
data[i].push({ key: 2, y, height, active: true })
for (let column of columns) {
data[`note_${column}`] = []
data[`longnote_${column}`] = []
}

let started = new Date().getTime()
let draw = () => {
data.t = (new Date().getTime() - started) / 1000
updateNotes()
context.render(data)
}
draw()
Expand All @@ -57,6 +55,30 @@ export function main() {

}

function generateRandomNotes() {
let notes = []
let chance = new Chance(1234)
let columns = ['SC', '1', '2', '3', '4', '5', '6', '7']
let nextId = 1
for (let column of columns) {
let position = 4
for (let j = 0; j < 2000; j ++) {
position += chance.integer({ min: 1, max: 6 }) / 8
let length = chance.bool({ likelihood: 20 }) ?
chance.integer({ min: 1, max: 8 }) / 8 : 0
let id = nextId++
if (length > 0) {
let end = { position: position + length }
notes.push({ position: position, end, column, id })
position = end.position
} else {
notes.push({ position: position, column, id })
}
}
}
return notes
}

function showCanvas(view) {

var { width, height } = view
Expand Down
36 changes: 36 additions & 0 deletions src/game/note-area.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@

import R from 'ramda'

export class NoteArea {
constructor(notes) {
this._notes = R.sortBy(position, notes)
}
getVisibleNotes(lower, upper, height) {
return this._notes.filter(note =>
note.end ?
!(note.position > upper || note.end.position < lower) :
!(note.position > upper || note.position < lower))
.map(note => {
if (!note.end) {
return { key: note.id, y: y(lower, upper, note.position, height),
column: note.column, }
} else {
let head = y(lower, upper, note.position, height)
let tail = y(lower, upper, note.end.position, height)
return { key: note.id, y: Math.min(head, tail),
height: Math.abs(head - tail),
column: note.column, }
}
})
}
}

export default NoteArea

function y(lower, upper, position, height) {
return height - (position - lower) / (upper - lower) * height
}

function position(event) {
return event.position
}
4 changes: 3 additions & 1 deletion src/scintillator/expression/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,9 @@ let log = debug('scintillator:expression')
import parser from './parser.pegjs'

function createFunction(code) {
return eval('(function(get) { return ' + code + ' })')
let fn = eval('(function(get) { return ' + code + ' })')
fn.displayName = '(' + code + ')'
return fn
}

export function Expression(text) {
Expand Down
5 changes: 3 additions & 2 deletions src/scintillator/nodes/lib/instance.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,9 @@ export function Instance(context, callback) {
},
bind(...pipeline) {
let sideEffect = onChange(pipeline.pop())
helper.onData(function(value) {
for (let f of pipeline) value = f(value)
helper.onData(function applyBinding(value) {
// using var here to optimize
for (var i = 0; i < pipeline.length; i ++) value = pipeline[i](value)
sideEffect(value)
})
},
Expand Down

0 comments on commit ed0b72f

Please sign in to comment.