From 2469a585581cf1474eada1c8148d03c43d36a7d2 Mon Sep 17 00:00:00 2001 From: Hans Hagen Date: Tue, 10 May 2011 18:34:00 +0200 Subject: beta 2011.05.10 18:34 --- tex/context/base/back-pdf.lua | 22 +++++ tex/context/base/grph-inc.lua | 9 +- tex/context/base/grph-swf.lua | 4 +- tex/context/base/l-pdfview.lua | 4 + tex/context/base/lpdf-swf.lua | 188 +++++++++++++++++++++++++++----------- tex/context/base/status-files.pdf | Bin 23557 -> 23551 bytes tex/context/base/status-lua.pdf | Bin 154280 -> 154316 bytes 7 files changed, 168 insertions(+), 59 deletions(-) diff --git a/tex/context/base/back-pdf.lua b/tex/context/base/back-pdf.lua index 7c736ebaf..294a7b05c 100644 --- a/tex/context/base/back-pdf.lua +++ b/tex/context/base/back-pdf.lua @@ -8,6 +8,8 @@ if not modules then modules = { } end modules ['back-pdf'] = { -- we will move code to lpdf-* files (second cleanup stage) +-- the push/pop is a mess (only needed for calculate ...) .. will be done differently + --[[ldx--

This module implements a couple of cleanup methods. We need these in order to meet the specification. Watch the double @@ -480,6 +482,26 @@ function codeinjections.setfigurealternative(data,figure) end end +function codeinjections.getdisplayfigure(request) + local figure = figures.initialize(request) + if not figure then + return + end + figure = figures.identify(figure) + if not figure then + return + end + figure = figures.check(figure) + if not figure then + return + end + local image = figure.status.private + if image then + img.immediatewrite(image) + end + return figure +end + function codeinjections.setfiguremask(data,figure) -- mark local request = data.request local mask = request.mask diff --git a/tex/context/base/grph-inc.lua b/tex/context/base/grph-inc.lua index 87fbd549e..7dee63eaf 100644 --- a/tex/context/base/grph-inc.lua +++ b/tex/context/base/grph-inc.lua @@ -306,8 +306,7 @@ end local lastfiguredata = nil -- will be topofstack or last so no { } (else problems with getfiguredimensions) local callstack = { } -function figures.push(request) - statistics.starttiming(figures) +function figures.initialize(request) local figuredata = new() if request then -- request.width/height are strings and are only used when no natural dimensions @@ -325,6 +324,12 @@ function figures.push(request) -- request.height = (h and h > 0) or false table.merge(figuredata.request,request) end + return figuredata +end + +function figures.push(request) + statistics.starttiming(figures) + local figuredata = figures.initialize(request) insert(callstack,figuredata) lastfiguredata = figuredata return figuredata diff --git a/tex/context/base/grph-swf.lua b/tex/context/base/grph-swf.lua index ed1c20eeb..88eed021a 100644 --- a/tex/context/base/grph-swf.lua +++ b/tex/context/base/grph-swf.lua @@ -79,8 +79,8 @@ function figures.checkers.swf(data) width = width, height = height, -- factor = number.dimenfactors.bp, - -- display = dr.display, - -- controls = dr.controls, + display = dr.display, + controls = dr.controls, -- label = dr.label, resources = dr.resources, } diff --git a/tex/context/base/l-pdfview.lua b/tex/context/base/l-pdfview.lua index 9bf525775..6fd3ac246 100644 --- a/tex/context/base/l-pdfview.lua +++ b/tex/context/base/l-pdfview.lua @@ -6,6 +6,10 @@ if not modules then modules = { } end modules ['l-pdfview'] = { license = "see context related readme files" } +-- Todo: figure out pdfopen/pdfclose on linux. Calling e.g. okular directly +-- doesn't work in linux when issued from scite as it blocks the editor (no +-- & possible or so). + local format, concat = string.format, table.concat pdfview = pdfview or { } diff --git a/tex/context/base/lpdf-swf.lua b/tex/context/base/lpdf-swf.lua index 2fec5df07..ef1855526 100644 --- a/tex/context/base/lpdf-swf.lua +++ b/tex/context/base/lpdf-swf.lua @@ -23,39 +23,98 @@ local pdfnull = lpdf.null local pdfreference = lpdf.reference local pdfimmediateobject = lpdf.immediateobject +local variables = interfaces.variables + local codeinjections = backends.pdf.codeinjections local nodeinjections = backends.pdf.nodeinjections local pdfannotation_node = nodes.pool.pdfannotation +local activations = { + click = "XA", + page = "PO", + focus = "PV", +} + +local deactivations = { + click = "XD", + page = "PI", + focus = "PC", +} + +table.setmetatableindex(activations, function() return activations .click end) +table.setmetatableindex(deactivations,function() return deactivations.focus end) + +local factor = number.dimenfactors.bp + +function img.package(image) + local boundingbox = image.bbox + local imagetag = "Im" .. image.index + local resources = pdfdictionary { + ProcSet = pdfarray { + pdfconstant("PDF"), + pdfconstant("ImageC") + }, + Resources = pdfdictionary { + XObject = pdfdictionary { + [imagetag] = pdfreference(image.objnum) + } + } + } + local width = boundingbox[3] + local height = boundingbox[4] + local xform = img.scan { + attr = resources(), + stream = format("%s 0 0 %s 0 0 cm /%s Do",width,height,imagetag), + bbox = { 0, 0, width/factor, height/factor }, + } + img.immediatewrite(xform) + return xform +end + + local function insertswf(spec) - local width, height, filename, resources = spec.width, spec.height, spec.foundname, spec.resources + local width = spec.width + local height = spec.height + local filename = spec.foundname + local resources = spec.resources + local display = spec.display + local controls = spec.controls local resources = resources and parametersets[resources] - local eref = codeinjections.embedfile { file = filename } + if display == nil or display == "" then + display = resources.display + end + if controls == nil or controls == "" then + controls = resources.controls + end + + controls = toboolean(variables[controls] or controls,true) + + local embeddedreference = codeinjections.embedfile { file = filename } local flash = pdfdictionary { Subtype = pdfconstant("Flash"), Instances = pdfarray { pdfdictionary { - Asset = eref, + Asset = embeddedreference, Params = pdfdictionary { - Binding = pdfconstant("Foreground") + Binding = pdfconstant("Background") -- Foreground makes swf behave erratic } }, }, } - local fref = pdfreference(pdfimmediateobject(tostring(flash))) + local flashreference = pdfreference(pdfimmediateobject(tostring(flash))) local configuration = pdfdictionary { - Configurations = pdfarray { fref }, + Configurations = pdfarray { flashreference }, Assets = pdfdictionary { Names = pdfarray { pdfstring(filename), - eref, + embeddedreference, } }, } @@ -64,9 +123,9 @@ local function insertswf(spec) local names = configuration.Assets.Names local function add(filename) local filename = gsub(filename,"%./","") - local eref = codeinjections.embedfile { file = filename, keepdir = true } + local embeddedreference = codeinjections.embedfile { file = filename, keepdir = true } names[#names+1] = pdfstring(filename) - names[#names+1] = eref + names[#names+1] = embeddedreference end local paths = resources.paths if paths then @@ -85,58 +144,77 @@ local function insertswf(spec) end end - local cref = pdfreference(pdfimmediateobject(tostring(configuration))) + local configurationreference = pdfreference(pdfimmediateobject(tostring(configuration))) local activation = pdfdictionary { - Activation = pdfdictionary { - Type = pdfconstant("RichMediaActivation"), - Condition = pdfconstant("PO"), - Configuration = fref, - Animation = pdfdictionary { - Subtype = pdfconstant("Linear"), - Speed = 1, - Playcount = 1, - }, - Deactivation = pdfdictionary { - Type = pdfconstant("RichMediaDeactivation"), - Condition = pdfconstant("XD"), - }, - Presentation = pdfdictionary { - PassContextClick = false, - Style = pdfconstant("Embedded"), - Toolbar = false, - NavigationPane = false, - Transparent = true, - Window = pdfdictionary { - Type = pdfconstant("RichMediaWindow"), - Width = pdfdictionary { - Default = 100, - Min = 100, - Max = 100, - }, - Height = pdfdictionary { - Default = 100, - Min = 100, - Max = 100, - }, - Position = pdfdictionary { - Type = pdfconstant("RichMediaPosition"), - HAlign = pdfconstant("Near"), - VAlign = pdfconstant("Near"), - HOffset = 0, - VOffset = 0, - } + Type = pdfconstant("RichMediaActivation"), + Condition = pdfconstant(activations[resources.open]), + Configuration = flashreference, + Animation = pdfdictionary { + Subtype = pdfconstant("Linear"), + Speed = 1, + Playcount = 1, + }, + Presentation = pdfdictionary { + PassContextClick = false, + Style = pdfconstant("Embedded"), + Toolbar = controls or false, + NavigationPane = false, + Transparent = true, + Window = pdfdictionary { + Type = pdfconstant("RichMediaWindow"), + Width = pdfdictionary { + Default = 100, + Min = 100, + Max = 100, + }, + Height = pdfdictionary { + Default = 100, + Min = 100, + Max = 100, + }, + Position = pdfdictionary { + Type = pdfconstant("RichMediaPosition"), + HAlign = pdfconstant("Near"), + VAlign = pdfconstant("Near"), + HOffset = 0, + VOffset = 0, } } - } + }, + -- View + -- Scripts } - local aref = pdfreference(pdfimmediateobject(tostring(activation))) + local deactivation = pdfdictionary { + Type = pdfconstant("RichMediaDeactivation"), + Condition = pdfconstant(deactivations[resources.close]), + } + + local richmediasettings = pdfdictionary { + Type = pdfconstant("RichMediaSettings"), + Activation = activation, + Deactivation = deactivation, + } + + local settingsreference = pdfreference(pdfimmediateobject(tostring(richmediasettings))) + + local appearance + + if display and display ~= "" then + local figure = codeinjections.getdisplayfigure { name = display, width = width, height = height } + if figure then + local image = img.package(figure.status.private) + local reference = image.objnum + appearance = reference and pdfdictionary { N = pdfreference(reference) } or nil + end + end local annotation = pdfdictionary { - Subtype = pdfconstant("RichMedia"), - RichMediaContent = cref, - RichMediaSettings = aref, + Subtype = pdfconstant("RichMedia"), + RichMediaContent = configurationreference, + RichMediaSettings = settingsreference, + AP = appearance, } return annotation, nil, nil @@ -149,8 +227,8 @@ function backends.pdf.nodeinjections.insertswf(spec) width = spec.width, height = spec.height, -- factor = spec.factor, - -- display = spec.display, - -- controls = spec.controls, + display = spec.display, + controls = spec.controls, -- label = spec.label, resources = spec.resources, } diff --git a/tex/context/base/status-files.pdf b/tex/context/base/status-files.pdf index 5a136355c..575e68449 100644 Binary files a/tex/context/base/status-files.pdf and b/tex/context/base/status-files.pdf differ diff --git a/tex/context/base/status-lua.pdf b/tex/context/base/status-lua.pdf index 79df508e0..236ec43d3 100644 Binary files a/tex/context/base/status-lua.pdf and b/tex/context/base/status-lua.pdf differ -- cgit v1.2.3