WO2003103212A2 - System for multimedia rendering in a portable device - Google Patents

System for multimedia rendering in a portable device Download PDF

Info

Publication number
WO2003103212A2
WO2003103212A2 PCT/US2003/017690 US0317690W WO03103212A2 WO 2003103212 A2 WO2003103212 A2 WO 2003103212A2 US 0317690 W US0317690 W US 0317690W WO 03103212 A2 WO03103212 A2 WO 03103212A2
Authority
WO
WIPO (PCT)
Prior art keywords
multimedia
rendering
multimedia content
portable device
content
Prior art date
Application number
PCT/US2003/017690
Other languages
French (fr)
Other versions
WO2003103212A3 (en
Inventor
Srinivas Patwari
Original Assignee
Qualcomm Incorporated
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US10/453,091 external-priority patent/US20040083015A1/en
Priority to NZ536703A priority Critical patent/NZ536703A/en
Priority to JP2004510169A priority patent/JP4943650B2/en
Priority to IL16527803A priority patent/IL165278A0/en
Priority to CA002488470A priority patent/CA2488470A1/en
Priority to BRPI0311545-3A priority patent/BR0311545A/en
Application filed by Qualcomm Incorporated filed Critical Qualcomm Incorporated
Priority to MXPA04012143A priority patent/MXPA04012143A/en
Priority to EP03756403A priority patent/EP1522024A4/en
Priority to AU2003251399A priority patent/AU2003251399C1/en
Priority to KR10-2004-7019567A priority patent/KR20050010851A/en
Publication of WO2003103212A2 publication Critical patent/WO2003103212A2/en
Publication of WO2003103212A3 publication Critical patent/WO2003103212A3/en
Priority to HK05109690.9A priority patent/HK1075521A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/41Structure of client; Structure of client peripherals
    • H04N21/414Specialised client platforms, e.g. receiver in car or embedded in a mobile appliance
    • H04N21/41407Specialised client platforms, e.g. receiver in car or embedded in a mobile appliance embedded in a portable device, e.g. video client on a mobile phone, PDA, laptop
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • G06F15/163Interprocessor communication
    • G06F15/167Interprocessor communication using a common memory, e.g. mailbox
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/72Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
    • H04M1/724User interfaces specially adapted for cordless or mobile telephones
    • H04M1/72403User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/72Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
    • H04M1/724User interfaces specially adapted for cordless or mobile telephones
    • H04M1/72403User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality
    • H04M1/72406User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality by software upgrading or downloading
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/431Generation of visual interfaces for content selection or interaction; Content or additional data rendering
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/72Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
    • H04M1/724User interfaces specially adapted for cordless or mobile telephones
    • H04M1/72403User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality
    • H04M1/72409User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality by interfacing with external accessories
    • H04M1/72412User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality by interfacing with external accessories using two-way short-range wireless interfaces
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/72Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
    • H04M1/724User interfaces specially adapted for cordless or mobile telephones
    • H04M1/72403User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality
    • H04M1/7243User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality with interactive means for internal management of messages

Definitions

  • the present invention relates generally to multimedia processing, and more particularly, to a system for multimedia rendering in a portable device having an embedded controller.
  • PDAs personal digital assistants
  • paging devices that are small, lightweight, and can be easily carried by users.
  • these devices include an embedded controller with limited memory resources. For example, the amount of available memory may be limited by the small size of the device.
  • One technique used to overcome compatibility problems requires that the multimedia content be in a format that is specifically compatible with the rendering resources available on the portable device. For example, if a content developer wishes to produce video content for use on a specific portable device, the developer tailors the video content to be exactly compatible with the video rendering resources available on the portable device.
  • a multimedia system including methods and apparatus, is provided for rendering multimedia content on a portable device.
  • the portable device may be a cellular telephone with an embedded controller and limited memory resources that executes program instructions to render multimedia content using the available rendering resources of the device.
  • the multimedia system is a small and efficient implementation that uses few resources and is particularly well suited for use in portable devices having embedded controllers with limited memory resources.
  • the system comprises a collection of format handlers to control the rendering resources of the device.
  • Each format handler is designed to process multimedia content having a specific format, and thereby control the rendering resources of the device to render that content. For example, each format handler renders (a specifically formatted) multimedia audio or video file (plays and understands it). The format handler determines what resources the content needs, reads the file, and calls the correct resources.
  • the portable device includes a high level application program interface (API) that the format handler uses to perform the task.
  • API application program interface
  • Each format handler can be included as part of the multimedia system in the portable device at manufacture, or can be downloaded dynamically.
  • the multimedia system provides an extensible architecture that allows the system to be expanded by adding new format handlers to render new content types as they are developed.
  • the architecture of the multimedia system is beneficial to both multimedia users and developers. For example, it allows developers to write their own format handlers for use on a wireless platform. And multimedia users benefit because the system provides a simple interface to allow all types of content to be rendered without having to know the exact configuration of the rendering device.
  • a method for rendering multimedia content in a portable device having an embedded processor.
  • the portable device further comprises one or more rendering resources.
  • the method comprises generating a multimedia object based on the multimedia content, associating a format handler with the multimedia object, and controlling a selected rendering resource using the format handler to render the multimedia content from the multimedia object.
  • a multimedia system for rendering multimedia content in a portable device having an embedded processor.
  • the portable device comprises one or more rendering resources.
  • the multimedia system comprises create media logic that operates to generate a multimedia object based on the multimedia content.
  • the system also comprises selection logic that operates to associate a format handler with the multimedia object.
  • the system also comprises format handling logic that operates to control a selected rendering to render the multimedia content from the multimedia object.
  • a computer-readable medium comprises computer-executable instructions for rendering multimedia content in a portable device having an embedded processor.
  • the portable device further comprises one or more rendering resources.
  • the instructions when executed perform a method that comprises generating a multimedia object based on the multimedia content, associating a format handler with the multimedia object, and controlling a selected rendering resource using the format handler to render the multimedia content from the multimedia object.
  • a multimedia system for rendering multimedia content in a portable device having an embedded processor.
  • the portable device further comprises one or more rendering resources.
  • the multimedia system comprises means for generating a multimedia object based on the multimedia content.
  • the system also comprises means for associating a format handler with the multimedia object.
  • the system also comprises means for controlling a selected rendering resource using the format handler to render the multimedia content from the multimedia object.
  • FIG. 1 illustrates a data network that includes a portable wireless device with an embedded controller suitable for implementing one embodiment of a multimedia system to render multimedia content
  • FIG. 2 shows a functional block diagram illustrating one embodiment of the portable device of FIG. 1 that includes one embodiment of a multimedia system that operates to render multimedia content
  • FIG. 3 shows a detailed block diagram of one embodiment of the multimedia system of FIG. 2
  • FIG. 4 shows one embodiment of a state machine managed by a format handler to render multimedia content
  • FIG. 5 shows one embodiment of a method for rendering multimedia content in a portable device.
  • the portable device has an embedded controller and limited resources (i.e., limited memory capacity), and the system operates to render multimedia content using the available rendering resources of the device.
  • limited resources i.e., limited memory capacity
  • the multimedia system interacts with a runtime environment executing on the device that is used to simplify operation of the device, such as by providing generalized calls for device specific resources.
  • a runtime environment executing on the device that is used to simplify operation of the device, such as by providing generalized calls for device specific resources.
  • One such runtime environment is the Binary Runtime Environment for WirelessTM (BREWTM) software platform developed by QUALCOMM, Inc., of San Diego, California.
  • BREWTM Binary Runtime Environment for WirelessTM
  • the multimedia system is implemented on a portable device executing a runtime environment, such as the BREW software platform.
  • one or more embodiments of the multimedia system are suitable for use with other types of runtime environments to render multimedia content on a portable device.
  • FIG. 1 illustrates a data network 100 that includes a portable wireless device 102 with an embedded controller suitable for implementing one embodiment of a multimedia system to render multimedia content.
  • the device 102 comprises one embodiment of a multimedia system 104 that will hereinafter be referred to as "-Media.”
  • the wireless device 102 communicates with a network server 106 over a wireless network 108 using wireless communication channels 110.
  • the device 102 comprises a cellular telephone that may transmit and/or receive voice information over the wireless network 108.
  • other suitable portable devices include, but are not limited to, PDAs, email devices, pagers, tablet computers, mobile telephones or virtually any other type of portable device that includes multimedia-rendering resources.
  • the device 102 may also receive multimedia applications or content over the wireless network 108.
  • multimedia applications 112 and 114 may be downloaded to the device 102 from the network server 106.
  • multimedia content 116 may also be downloaded to the device 102 from the network server 106. It is also possible to download multimedia applications or content to the device 102 from any other network entity coupled to the wireless network 108.
  • the device 102 also couples directly to a local system, such as a local workstation 118, via a direct link 120.
  • a local workstation 118 downloads multimedia applications or content to the device 102 using the direct link 120.
  • the multimedia application 122 is downloaded to the device 102 from the workstation 118 using the link 120.
  • the IMedia system 104 may be downloaded from the server 106 to the device
  • the IMedia system 104 may be downloaded to the device 102 from the workstation 118 via the link 120, or may be installed in the device during manufacture.
  • the IMedia system 104 is provided on a computer readable media, such as a floppy disk, and is loaded onto the system 118 for transmission to the device 102.
  • the IMedia system 104 may be stored on a computer readable memory device, such as a memory card (not shown), and plugged directly into the device 102, so that the IMedia system 104 may execute on the device 102.
  • the device 102 may receive the -Media system 104 in a wireless transmission, a wired transmission, or by retrieving it directly from a memory device.
  • the network 100 may also include other types of portable devices, such as other types of wireless and non-wireless portable devices, and these devices may communicate with the server 106 or any other network entities utilizing various network types and communication architectures, including wireless and non-wireless networks, private and public networks, switched and non-switched networks, direct links and any combination thereof to download one or more embodiments of the IMedia system 104 to render multimedia content.
  • portable devices such as other types of wireless and non-wireless portable devices
  • these devices may communicate with the server 106 or any other network entities utilizing various network types and communication architectures, including wireless and non-wireless networks, private and public networks, switched and non-switched networks, direct links and any combination thereof to download one or more embodiments of the IMedia system 104 to render multimedia content.
  • FIG. 2 shows a functional block diagram illustrating one embodiment of the device 102 that includes one embodiment of the IMedia system 104 that operates to render multimedia content.
  • the device 102 comprises processing logic 202 that is coupled to an internal data bus 204 and a stack memory 216. Also coupled to the internal data bus 204 are instruction memory 206, multimedia application/content memory 208, heap memory 210, user interface 212, display logic 216, audio logic 218, and input/output (I/O) interface 214.
  • instruction memory 206 Also coupled to the internal data bus 204 are instruction memory 206, multimedia application/content memory 208, heap memory 210, user interface 212, display logic 216, audio logic 218, and input/output (I/O) interface 214.
  • the processing logic 202 executes program instructions stored in the instruction memory 206 to generate a runtime environment 220.
  • the runtime environment 220 may be the BREW environment or other suitable runtime environment.
  • the processing logic 202 utilizes the stack memory 216 to store program data or instructions on a temporary basis.
  • the processing logic 202 may store constants, variables, program addresses, pointers, instructions or other information items on the stack memory 216.
  • the processing logic 202 may store information on a temporary basis in the heap memory 210.
  • the heap memory comprises virtually any type of memory suitable for the storage and retrieval of information by the processing logic 202.
  • the processing logic 202 comprises a CPU, gate array, hardware logic, software, or a combination of hardware and software.
  • the processing logic 202 generally comprises logic to execute machine-readable instructions.
  • the instruction memory 206 comprises RAM, ROM, FLASH, EEROM, or any other suitable type of memory, or a combination thereof.
  • the instruction memory 206 is located internal to the device 102, and in another embodiment, the instruction memory 206 comprises a removable memory card or memory device that may be selectively attached to the device 102, and thereby couple to the internal bus 204.
  • the instruction memory 206 may comprise virtually any type of memory that is capable of storing instructions that may be executed by the processing logic 202.
  • the user interface 212 receives user input, for example, from a keypad, pointing device, touch pad, or other input mechanisms to allow a user to interact with the device 102.
  • the display logic 216 comprises logic to output information to a device display.
  • the device may include an LCD, LED or other type of display resource.
  • the audio logic 218 comprises logic to output audio information to a device speaker(s), remote speaker(s) or audio system, or other type of sound resource.
  • a pair of remote speakers may receive the output of the audio logic 218 to render audio information to a device user.
  • the display logic 216 and the audio logic 218 may comprise hardware and/or software in any combination to allow the device 102 to render visual or audio information to the device user.
  • the I/O interface 214 operates to transmit and receive information between the device 102 and external devices, systems, and/or networks.
  • the I/O interface 214 comprises a radio transceiver circuit (not shown) that operates to transmit and receive information over a wireless data network using, for example, communication link 106.
  • the transceiver comprises circuitry that modulates information received from the processing logic 202 and converts the modulated information into high frequency signals suitable for wireless transmission.
  • the transceiver also comprises circuitry to convert received high frequency communication signals into signals suitable for demodulation and subsequent processing by the processing logic 202.
  • the I/O interface 214 comprises a transceiver that operates to transmit and receive information over a hardwired communication link, such as a telephone line, to communicate with a remote system on a public data network, such as the Internet.
  • the I/O interface 214 comprises circuitry that operates to communicate with local devices, such as the local workstation 116 using the link 120.
  • the I/O interface 214 may also include circuitry (such as serial or parallel port logic) to communicate with a printer or other local computer or device, such as floppy disk or memory card.
  • the I O interface 214 may comprise any type of hardware, software, or combination thereof to allow the device 102 to communicate with other local or remotely located devices or systems.
  • execution of program instructions by the processing logic 202 causes the -Media system 104 to be generated.
  • -Media instructions that when executed generate the -Media system 104 may be stored in the instructions memory 206.
  • the -Media system 104 interacts with the runtime environment 220 to render multimedia applications and content on the device 102.
  • multimedia applications and content may be downloaded to the device 102 via the wireless network 108 and stored in the memory 208.
  • the -Media system 104 retrieves the multimedia content stored in the memory 208 via the internal bus 204 and processes the content to render it on the device 102 by interacting with the device's rendering resources (i.e., display logic, audio logic, etc.) via the runtime environment 220.
  • the -Media system 104 also operates to process and render streaming multimedia content. For example, streaming multimedia content downloaded from the network 108 to the device 102 is rendered on the device 102 using the -Media system 104.
  • the configuration of the device 102 is just one configuration suitable for implementing one embodiment of the IMedia system 104 to render multimedia applications and content. It is also possible to implement the -Media system 104 using other devices or device configurations within the scope of the present invention.
  • FIG. 3 shows a detailed block diagram of one embodiment of the -Media system
  • the device 102 includes native hardware 302 that comprises processing logic 202 and may optionally include a multimedia processor 304 that is specifically designed to process multimedia information. It will be assumed without further description that the native hardware 302 includes logic to operate the device's rendering resources (i.e., display logic 216, etc.) and that the processing logic 202 and the multimedia processor 304 may operate to control these resources.
  • native hardware 302 includes logic to operate the device's rendering resources (i.e., display logic 216, etc.) and that the processing logic 202 and the multimedia processor 304 may operate to control these resources.
  • the device 102 also includes native multimedia software 306 that comprises audiol 308, audio2 310 and video 312 modules. These modules represent low-level software modules that are used to directly communicate with the native hardware 302 to control selected rendering resources. For example, the video module 312 communicates with the multimedia processor 304 to control video rendering resources. Although one embodiment is shown, it is also possible to have fewer or more multimedia software modules 306 and these modules may communicate with all types of native hardware 302. Thus, other native hardware 302 and software 306 configurations are possible within the scope of the invention. [0044] During operation, the device 102 executes program instructions to generate the runtime environment 220, which in one embodiment, is the Brew environment. It is then possible to execute the IMedia instructions to generate the -Media system 104 to render multimedia content in conjunction with the runtime environment. For example, the IMedia instructions may be downloaded to the device via the wireless network 108 and stored in the instruction memory 206.
  • the IMedia system 104 operates to abstract multimedia content handling and define a framework of multimedia interfaces.
  • the -Media system 104 operates to provide the following features.
  • the -Media system 104 includes a create media utility 324, media data structure
  • -Media abstraction 328 which illustrates a basic -Media object that is created during operation of the -Media system 104.
  • the -Media abstraction 328 is an abstract interface enabling registration and handling of a multimedia content type.
  • the -Media abstraction 328 maintains a reference to media data in the media data structure 326.
  • the media data structure 326 operates to encapsulate the media data source or sink. This allows the -Media system 104 to stream media data from or to various sources or destinations.
  • the media data structure 326 is formed from data structure logic that comprises the processing logic 202 executing program instructions to generate the media data structure 326 in the memory 210.
  • the create media utility 324 performs several functions. First, the create media utility 324 operates to receive multimedia applications or content for rendering. For example, the multimedia applications or content may be stored in the memory 208, and this content includes a function call to the create media utility 324. Second, the create media utility 324 processes the multimedia content to create an -Media object 328 based on the information contained in the media data 326. After creating the IMedia object, it sets the media data and places the -Media object in the ready state. In one embodiment, the create media utility 326 is formed from create media logic that comprises the processing logic 202 executing program instructions to create the -Media object 328 in the memory 210 and perform the functions of the create media utility described herein.
  • the create media utility 326 includes selection logic that comprises the processing logic 202 executing program instructions to select a format handler to associate with the -Media object 328 and perform other functions described herein. For example, the selection logic evaluates the data structure 326 associated with the media content to determine which format handler to select.
  • the IMedia system 104 comprises a collection of format handlers (FH).
  • the -Media system 104 comprises MIDI 314, MP3 316, MPEG4 318, and ADCPM 320 format handlers.
  • These format handlers provide interfaces 322 between IMedia objects 328 and the multimedia rendering hardware and software of the device 102.
  • the format handlers interpret a common instruction set so that multimedia applications or content may utilize the same instructions to instruct the format handlers to perform similar tasks, such as play, stop, rewind, etc. Any number of format handlers may be used, and new format handlers may be added to render new types of multimedia content.
  • the format handlers are formed from format handling logic that comprises the processing logic 202 executing program instructions to perform the functions of the format handlers described herein.
  • a common instruction set instructs the format handlers to render multimedia content and provides a mechanism for passing parameters and status. A sample of the instructions included in the common instruction set is as follows.
  • the -Media_SetMediaParm() instruction may be included in the IMedia object to instruct the format handler to set specific parameters, settings, or variables associated with the format handler.
  • parameters associated with a format handler designed to render MPEG video can be set using the IMedia_SetMediaParm() instruction.
  • specific format handlers may also interpret additional instructions (not shown above) that may be included in the IMedia object 328 and that are used to control specific function of the resource being controlled.
  • a format handler is software running on the portable device as part of the IMedia system 104.
  • the format handler may be a combination of hardware and software.
  • format handlers may be added to the -Media system as they become available so that the -Media system is extensible and able to render new types of multimedia content as it becomes available.
  • format handlers register themselves (their MIME type) with the runtime environment and they can be detected by multimedia applications by querying for the MIME type or enumerating a list of supported (registered) format handlers in the system.
  • Each format handler provides a selection of functions that include, but is not limited to, the following.
  • API application program interface
  • FIG. 4 shows one embodiment of a state machine 400 managed by a format handler to render multimedia content, for example, the format handler 318.
  • the initial state of the format handler is IDLE 402.
  • the state of the format handler goes to READY 404.
  • the format handler may proceed to either PLAY 406 or RECORD 408 states based on commands associated with the multimedia content.
  • the format handler may go to PLAY_PAUSE 410 or REC_PAUSE 412 states. From these states, it is also possible to resume the corresponding PLAY 406 and RECORD 408 states.
  • the format handler may also STOP 414 and return to the READY 404 state.
  • each format handler uses the state machine 400, it is possible for each format handler to control the device's rendering resources to render multimedia applications or content (-Media object) that has been associated with that formal handler.
  • the format handler it is also possible for the format handler to implement a different state machine than the one shown in FIG. 4.
  • FIG. 5 shows one embodiment of a method 500 for rendering multimedia content in a portable device.
  • a multimedia application or content is created using -Media constructs so that it may be rendered on a portable device.
  • application developers create -Media objects using the create media utility 324.
  • the number of -Media objects and the capabilities, such as simultaneous playback or recording, are dependent on the device. All -Media objects follow the basic state machine shown in FIG. 4.
  • the following steps can be used to create and use an -Media object.
  • [0060] 1. Create a media data structure and initialize it based on the media data source/sink.
  • the AEEMediaData is defined as follows, typedef struct
  • AEECLSID clsData // Type of media data void * pData; // Context sensitive data (see table) uint32 dwSize; // Context sensitive data (see table) ⁇ AEEMediaData;
  • the multimedia content is downloaded to the portable device for rendering.
  • the application or content may be downloaded to the device via the wireless data network 108.
  • the content may be rendered as streaming content, or stored in memory and rendered at a later time.
  • a media data structure is created and initialized based on media source or sink characteristics included in the received content.
  • the media data structure is stored in the media data structure 326.
  • the media type is derived based on file extension, file content, or a signature included in the file.
  • an -Media object is created using the associated data structure.
  • the create media utility 324 is used to create the -Media object.
  • the -Media object is returned in the ready state 404.
  • an optional step may be performed to register a notification function if it is desirable to received asynchronous events from the -Media object.
  • the -Media object is associated with a format handler and the multimedia application or content is rendered on the portable device.
  • the format handler may provide any of the functions of the state machine 400 to render to multimedia content.
  • the content has been rendered and the -Media object is no longer needed, it is released.
  • CApp is an instance of a BREW applet global structure.
  • nRet AEEMediaUtil_CreateMedia(pme->a.pIShell, &md, pme->m_pIMedia);
  • a multimedia system including methods and apparatus operates to render multimedia applications and content on a resource-limited portable device having an embedded controller. Accordingly, while one or more embodiments of the methods and apparatus have been illustrated and described herein, it will be appreciated that various changes can be made to the embodiments without departing from their spirit or essential characteristics. Therefore, the disclosures and descriptions herein are intended to be illustrative, but not limiting, of the scope of the invention, which is set forth in the following claims.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Signal Processing (AREA)
  • Computer Hardware Design (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Multimedia (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Mathematical Physics (AREA)
  • Databases & Information Systems (AREA)
  • Data Mining & Analysis (AREA)
  • Mobile Radio Communication Systems (AREA)
  • Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
  • Stored Programmes (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

A multimedia system for rendering multimedia content in a portable device having an embedded processor. The portable device includes one or more rendering resources. A method is provided that performs operations of generating a multimedia object based on the multimedia content, associating a format handler with the multimedia object, and controlling a selected rendering resource using the format handler to render the multimedia content from the multimedia object.

Description

SYSTEM FOR MULTIMEDIA RENDERING IN A PORTABLE
DEVICE
CROSS REFERENCE TO RELATED APPLICATIONS [0001] This Application claims the benefit of priority from co-pending U.S. Provisional
Patent Application Serial No. 60/385,942 entitled "Multimedia Processing" filed on June 4, 2002. This Application also claims the benefit of priority from co-pending U.S. Provisional Application entitled "Multimedia Processing" filed on April 25, 2003. The disclosures of both of the above-identified Provisional Applications are incorporated by reference herein in their entirety for all purposes.
BACKGROUND
I. FIELD
[0002] The present invention relates generally to multimedia processing, and more particularly, to a system for multimedia rendering in a portable device having an embedded controller.
II. DESCRIPTION OFTHERELATEDART
[0003] Advances in technology have resulted in smaller and more powerful personal computing devices. For example, there currently exist a variety of portable cellular telephones, personal digital assistants (PDAs), and paging devices that are small, lightweight, and can be easily carried by users. Typically, these devices include an embedded controller with limited memory resources. For example, the amount of available memory may be limited by the small size of the device.
[0004] However, there is an increasing need for these devices to handle larger amounts of data and to execute programs that are more sophisticated. For example, users are demanding remote access to interactive programs, such as gaming programs that require the portable device to provide fast and efficient rendering of multimedia applications and content. For example, users would like to use their portable devices to view and hear multimedia content, such as video clips, animations, movies, and audio, such as music content provided in MP3 format. [0005] In order to render multimedia content on a portable device, it is necessary to control the rendering resources of the device. For example, one type of portable device may include a small low-resolution display screen or an audio speaker, and another type of portable device may include a larger and higher-resolution display and two-speaker stereo capabilities. Thus, each type of portable device may have different multimedia rendering resources with which to render multimedia content. Therefore, compatibility problems have to be overcome when providing multimedia content for use on a wide variety of portable devices having various configurations and rendering resources.
[0006] One technique used to overcome compatibility problems requires that the multimedia content be in a format that is specifically compatible with the rendering resources available on the portable device. For example, if a content developer wishes to produce video content for use on a specific portable device, the developer tailors the video content to be exactly compatible with the video rendering resources available on the portable device.
[0007] Unfortunately, it is expensive and inefficient to produce multimedia content that is tailored for each portable device that the content is to be rendered on. For example, a content developer would need to modify the content for different portable devices, and thereby generate multiple versions of the same content. Also, the content developer would have to constantly update its content as new rendering resources become available.
[0008] Therefore, what is needed is a system that allows multimedia content to be rendered on a variety of portable devices without having to tailor the content to account for different rendering resources available on each device. The system should operate to allow all types of multimedia content to be rendered and provide an extensible architecture that allows for the rendering of new multimedia formats as they are developed.
SUMMARY
[0009] In one or more embodiments, a multimedia system, including methods and apparatus, is provided for rendering multimedia content on a portable device. For example, the portable device may be a cellular telephone with an embedded controller and limited memory resources that executes program instructions to render multimedia content using the available rendering resources of the device. In one or more embodiments, the multimedia system is a small and efficient implementation that uses few resources and is particularly well suited for use in portable devices having embedded controllers with limited memory resources.
[0010] In one embodiment, the system comprises a collection of format handlers to control the rendering resources of the device. Each format handler is designed to process multimedia content having a specific format, and thereby control the rendering resources of the device to render that content. For example, each format handler renders (a specifically formatted) multimedia audio or video file (plays and understands it). The format handler determines what resources the content needs, reads the file, and calls the correct resources. The portable device includes a high level application program interface (API) that the format handler uses to perform the task. Each format handler can be included as part of the multimedia system in the portable device at manufacture, or can be downloaded dynamically. It is therefore possible for one or more embodiments of the multimedia system to utilize a collection of format handlers, and thereby operate to render multimedia content in a variety of portable devices without having to tailor the content based on the rendering resources available at each device. Additionally, the multimedia system provides an extensible architecture that allows the system to be expanded by adding new format handlers to render new content types as they are developed.
[0011] The architecture of the multimedia system is beneficial to both multimedia users and developers. For example, it allows developers to write their own format handlers for use on a wireless platform. And multimedia users benefit because the system provides a simple interface to allow all types of content to be rendered without having to know the exact configuration of the rendering device.
[0012] In one embodiment, a method is provided for rendering multimedia content in a portable device having an embedded processor. The portable device further comprises one or more rendering resources. The method comprises generating a multimedia object based on the multimedia content, associating a format handler with the multimedia object, and controlling a selected rendering resource using the format handler to render the multimedia content from the multimedia object.
[0013] In another embodiment, a multimedia system is provided for rendering multimedia content in a portable device having an embedded processor. The portable device comprises one or more rendering resources. The multimedia system comprises create media logic that operates to generate a multimedia object based on the multimedia content. The system also comprises selection logic that operates to associate a format handler with the multimedia object. The system also comprises format handling logic that operates to control a selected rendering to render the multimedia content from the multimedia object.
[0014] In another embodiment, a computer-readable medium is provided that comprises computer-executable instructions for rendering multimedia content in a portable device having an embedded processor. The portable device further comprises one or more rendering resources. The instructions when executed perform a method that comprises generating a multimedia object based on the multimedia content, associating a format handler with the multimedia object, and controlling a selected rendering resource using the format handler to render the multimedia content from the multimedia object.
[0015] In another embodiment, a multimedia system is provided for rendering multimedia content in a portable device having an embedded processor. The portable device further comprises one or more rendering resources. The multimedia system comprises means for generating a multimedia object based on the multimedia content. The system also comprises means for associating a format handler with the multimedia object. The system also comprises means for controlling a selected rendering resource using the format handler to render the multimedia content from the multimedia object.
[0016] Other aspects, advantages, and features of the present invention will become apparent after review of the hereinafter set forth Brief Description of the Drawings, Detailed Description of the Invention, and the Claims
BRIEF DESCRIPTION OF THE DRAWINGS
[0017] The foregoing aspects and the attendant advantages of the embodiments described herein will become more readily apparent by reference to the following detailed description when taken in conjunction with the accompanying drawings wherein:
[0018] FIG. 1 illustrates a data network that includes a portable wireless device with an embedded controller suitable for implementing one embodiment of a multimedia system to render multimedia content; [0019] FIG. 2 shows a functional block diagram illustrating one embodiment of the portable device of FIG. 1 that includes one embodiment of a multimedia system that operates to render multimedia content; [0020] FIG. 3 shows a detailed block diagram of one embodiment of the multimedia system of FIG. 2; [0021] FIG. 4 shows one embodiment of a state machine managed by a format handler to render multimedia content; and [0022] FIG. 5 shows one embodiment of a method for rendering multimedia content in a portable device.
DETAILED DESCRIPTION
[0023] The following detailed description describes a multimedia system, including methods and apparatus, for rendering multimedia content in a portable device. In one or more embodiments, the portable device has an embedded controller and limited resources (i.e., limited memory capacity), and the system operates to render multimedia content using the available rendering resources of the device.
[0024] In one or more embodiments, the multimedia system interacts with a runtime environment executing on the device that is used to simplify operation of the device, such as by providing generalized calls for device specific resources. One such runtime environment is the Binary Runtime Environment for Wireless™ (BREW™) software platform developed by QUALCOMM, Inc., of San Diego, California. In the following description, it will be assumed that the multimedia system is implemented on a portable device executing a runtime environment, such as the BREW software platform. However, one or more embodiments of the multimedia system are suitable for use with other types of runtime environments to render multimedia content on a portable device.
[0025] FIG. 1 illustrates a data network 100 that includes a portable wireless device 102 with an embedded controller suitable for implementing one embodiment of a multimedia system to render multimedia content. For example, the device 102 comprises one embodiment of a multimedia system 104 that will hereinafter be referred to as "-Media." In the network 100, the wireless device 102 communicates with a network server 106 over a wireless network 108 using wireless communication channels 110. [0026] In one embodiment, the device 102 comprises a cellular telephone that may transmit and/or receive voice information over the wireless network 108. However, one or more embodiments of the described multimedia system are suitable for use with other types of portable devices. For example, other suitable portable devices include, but are not limited to, PDAs, email devices, pagers, tablet computers, mobile telephones or virtually any other type of portable device that includes multimedia-rendering resources.
[0027] The device 102 may also receive multimedia applications or content over the wireless network 108. For example, multimedia applications 112 and 114 may be downloaded to the device 102 from the network server 106. Additionally, multimedia content 116 may also be downloaded to the device 102 from the network server 106. It is also possible to download multimedia applications or content to the device 102 from any other network entity coupled to the wireless network 108.
[0028] In one embodiment, the device 102 also couples directly to a local system, such as a local workstation 118, via a direct link 120. In one embodiment, the local workstation 118 downloads multimedia applications or content to the device 102 using the direct link 120. For example, the multimedia application 122 is downloaded to the device 102 from the workstation 118 using the link 120.
[0029] The IMedia system 104 may be downloaded from the server 106 to the device
102 and operates on the device 102 to render multimedia applications or content. In another embodiment, the IMedia system 104 may be downloaded to the device 102 from the workstation 118 via the link 120, or may be installed in the device during manufacture.
[0030] In one embodiment, the IMedia system 104 is provided on a computer readable media, such as a floppy disk, and is loaded onto the system 118 for transmission to the device 102. In another embodiment, the IMedia system 104 may be stored on a computer readable memory device, such as a memory card (not shown), and plugged directly into the device 102, so that the IMedia system 104 may execute on the device 102. Thus, the device 102 may receive the -Media system 104 in a wireless transmission, a wired transmission, or by retrieving it directly from a memory device.
[0031] The network 100 may also include other types of portable devices, such as other types of wireless and non-wireless portable devices, and these devices may communicate with the server 106 or any other network entities utilizing various network types and communication architectures, including wireless and non-wireless networks, private and public networks, switched and non-switched networks, direct links and any combination thereof to download one or more embodiments of the IMedia system 104 to render multimedia content.
[0032] FIG. 2 shows a functional block diagram illustrating one embodiment of the device 102 that includes one embodiment of the IMedia system 104 that operates to render multimedia content. The device 102 comprises processing logic 202 that is coupled to an internal data bus 204 and a stack memory 216. Also coupled to the internal data bus 204 are instruction memory 206, multimedia application/content memory 208, heap memory 210, user interface 212, display logic 216, audio logic 218, and input/output (I/O) interface 214.
[0033] During operation of the device 102, the processing logic 202 executes program instructions stored in the instruction memory 206 to generate a runtime environment 220. The runtime environment 220 may be the BREW environment or other suitable runtime environment. To assist with instruction execution, the processing logic 202 utilizes the stack memory 216 to store program data or instructions on a temporary basis. For example, the processing logic 202 may store constants, variables, program addresses, pointers, instructions or other information items on the stack memory 216. In another embodiment, the processing logic 202 may store information on a temporary basis in the heap memory 210. The heap memory comprises virtually any type of memory suitable for the storage and retrieval of information by the processing logic 202.
[0034] In one or more embodiments, the processing logic 202 comprises a CPU, gate array, hardware logic, software, or a combination of hardware and software. Thus, the processing logic 202 generally comprises logic to execute machine-readable instructions.
[0035] The instruction memory 206 comprises RAM, ROM, FLASH, EEROM, or any other suitable type of memory, or a combination thereof. In one embodiment, the instruction memory 206 is located internal to the device 102, and in another embodiment, the instruction memory 206 comprises a removable memory card or memory device that may be selectively attached to the device 102, and thereby couple to the internal bus 204. Thus, the instruction memory 206 may comprise virtually any type of memory that is capable of storing instructions that may be executed by the processing logic 202. [0036] The user interface 212 receives user input, for example, from a keypad, pointing device, touch pad, or other input mechanisms to allow a user to interact with the device 102. The display logic 216 comprises logic to output information to a device display. For example, the device may include an LCD, LED or other type of display resource. The audio logic 218 comprises logic to output audio information to a device speaker(s), remote speaker(s) or audio system, or other type of sound resource. For example, a pair of remote speakers may receive the output of the audio logic 218 to render audio information to a device user. Thus, the display logic 216 and the audio logic 218 may comprise hardware and/or software in any combination to allow the device 102 to render visual or audio information to the device user.
[0037] The I/O interface 214 operates to transmit and receive information between the device 102 and external devices, systems, and/or networks. For example, in one embodiment, the I/O interface 214 comprises a radio transceiver circuit (not shown) that operates to transmit and receive information over a wireless data network using, for example, communication link 106. For example, the transceiver comprises circuitry that modulates information received from the processing logic 202 and converts the modulated information into high frequency signals suitable for wireless transmission. Similarly, the transceiver also comprises circuitry to convert received high frequency communication signals into signals suitable for demodulation and subsequent processing by the processing logic 202.
[0038] In another embodiment, the I/O interface 214 comprises a transceiver that operates to transmit and receive information over a hardwired communication link, such as a telephone line, to communicate with a remote system on a public data network, such as the Internet.
[0039] In still another embodiment, the I/O interface 214 comprises circuitry that operates to communicate with local devices, such as the local workstation 116 using the link 120. The I/O interface 214 may also include circuitry (such as serial or parallel port logic) to communicate with a printer or other local computer or device, such as floppy disk or memory card. Thus, the I O interface 214 may comprise any type of hardware, software, or combination thereof to allow the device 102 to communicate with other local or remotely located devices or systems.
[0040] During operation of the device 102, execution of program instructions by the processing logic 202 causes the -Media system 104 to be generated. For example, -Media instructions that when executed generate the -Media system 104 may be stored in the instructions memory 206. The -Media system 104 interacts with the runtime environment 220 to render multimedia applications and content on the device 102. For example, multimedia applications and content may be downloaded to the device 102 via the wireless network 108 and stored in the memory 208. In one embodiment, the -Media system 104 retrieves the multimedia content stored in the memory 208 via the internal bus 204 and processes the content to render it on the device 102 by interacting with the device's rendering resources (i.e., display logic, audio logic, etc.) via the runtime environment 220. The -Media system 104 also operates to process and render streaming multimedia content. For example, streaming multimedia content downloaded from the network 108 to the device 102 is rendered on the device 102 using the -Media system 104.
[0041] It should be noted that the configuration of the device 102 is just one configuration suitable for implementing one embodiment of the IMedia system 104 to render multimedia applications and content. It is also possible to implement the -Media system 104 using other devices or device configurations within the scope of the present invention.
[0042] FIG. 3 shows a detailed block diagram of one embodiment of the -Media system
104 for use in the device 102. The device 102 includes native hardware 302 that comprises processing logic 202 and may optionally include a multimedia processor 304 that is specifically designed to process multimedia information. It will be assumed without further description that the native hardware 302 includes logic to operate the device's rendering resources (i.e., display logic 216, etc.) and that the processing logic 202 and the multimedia processor 304 may operate to control these resources.
[0043] The device 102 also includes native multimedia software 306 that comprises audiol 308, audio2 310 and video 312 modules. These modules represent low-level software modules that are used to directly communicate with the native hardware 302 to control selected rendering resources. For example, the video module 312 communicates with the multimedia processor 304 to control video rendering resources. Although one embodiment is shown, it is also possible to have fewer or more multimedia software modules 306 and these modules may communicate with all types of native hardware 302. Thus, other native hardware 302 and software 306 configurations are possible within the scope of the invention. [0044] During operation, the device 102 executes program instructions to generate the runtime environment 220, which in one embodiment, is the Brew environment. It is then possible to execute the IMedia instructions to generate the -Media system 104 to render multimedia content in conjunction with the runtime environment. For example, the IMedia instructions may be downloaded to the device via the wireless network 108 and stored in the instruction memory 206.
[0045] The IMedia system 104 operates to abstract multimedia content handling and define a framework of multimedia interfaces. In one embodiment, the -Media system 104 operates to provide the following features.
1. Provides generic and easy access to device multimedia features and capabilities.
2. Shields complex application specific integrated circuit (ASIC) level multimedia
APIs and resource management.
3. Provides building blocks to develop complex multimedia applications.
4. Optionally derives media type based on file extension, file content, or a signature in file.
[0046] The -Media system 104 includes a create media utility 324, media data structure
326, and format handlers 314, 316, 318, and 320. Also shown as part of the IMedia system 104 is an -Media abstraction 328, which illustrates a basic -Media object that is created during operation of the -Media system 104. A detailed description of the compo'nents of the -Media system is provided as follows.
IMEDIA ABSTRACTION
[0047] The -Media abstraction 328 is an abstract interface enabling registration and handling of a multimedia content type. The -Media abstraction 328 maintains a reference to media data in the media data structure 326.
MEDIA DATA STRUCTURE
[0048] The media data structure 326 operates to encapsulate the media data source or sink. This allows the -Media system 104 to stream media data from or to various sources or destinations. In one embodiment, the media data structure 326 is formed from data structure logic that comprises the processing logic 202 executing program instructions to generate the media data structure 326 in the memory 210. CREATE MEDIA UTILITY
[0049] The create media utility 324 performs several functions. First, the create media utility 324 operates to receive multimedia applications or content for rendering. For example, the multimedia applications or content may be stored in the memory 208, and this content includes a function call to the create media utility 324. Second, the create media utility 324 processes the multimedia content to create an -Media object 328 based on the information contained in the media data 326. After creating the IMedia object, it sets the media data and places the -Media object in the ready state. In one embodiment, the create media utility 326 is formed from create media logic that comprises the processing logic 202 executing program instructions to create the -Media object 328 in the memory 210 and perform the functions of the create media utility described herein.
[0050] In one embodiment, the create media utility 326 includes selection logic that comprises the processing logic 202 executing program instructions to select a format handler to associate with the -Media object 328 and perform other functions described herein. For example, the selection logic evaluates the data structure 326 associated with the media content to determine which format handler to select.
FORMAT HANDLERS
[0051] In one embodiment, the IMedia system 104 comprises a collection of format handlers (FH). For example, the -Media system 104 comprises MIDI 314, MP3 316, MPEG4 318, and ADCPM 320 format handlers. These format handlers provide interfaces 322 between IMedia objects 328 and the multimedia rendering hardware and software of the device 102. In one embodiment, the format handlers interpret a common instruction set so that multimedia applications or content may utilize the same instructions to instruct the format handlers to perform similar tasks, such as play, stop, rewind, etc. Any number of format handlers may be used, and new format handlers may be added to render new types of multimedia content. In one embodiment, the format handlers are formed from format handling logic that comprises the processing logic 202 executing program instructions to perform the functions of the format handlers described herein. [0052] In one embodiment, a common instruction set instructs the format handlers to render multimedia content and provides a mechanism for passing parameters and status. A sample of the instructions included in the common instruction set is as follows.
1. -Media_SetMediaParm() ;sets parameters of the FH 2 -Media_GetMediaParm() ;gets parameters from the FH 3 IMedia_SetMediaData() ;sets media data 4 -Media_GetMediaData() ;gets media data 5 -Media_GetClass-D() ;gets class ID 6 -Media_GetState() ;gets state 7. -Media_RegisterNotify() registers a call back with FH 8. IMedia_Play() ;issues play command to FH 9 IMedia_Stop() ;issues stop command to FH 10 -Media_SetRect() ;set video parameters
[0053] For example, the -Media_SetMediaParm() instruction may be included in the IMedia object to instruct the format handler to set specific parameters, settings, or variables associated with the format handler. For example, parameters associated with a format handler designed to render MPEG video can be set using the IMedia_SetMediaParm() instruction. In other embodiments, specific format handlers may also interpret additional instructions (not shown above) that may be included in the IMedia object 328 and that are used to control specific function of the resource being controlled.
[0054] In one embodiment, a format handler is software running on the portable device as part of the IMedia system 104. In another embodiment, the format handler may be a combination of hardware and software. Furthermore, format handlers may be added to the -Media system as they become available so that the -Media system is extensible and able to render new types of multimedia content as it becomes available.
[0055] During operation, format handlers register themselves (their MIME type) with the runtime environment and they can be detected by multimedia applications by querying for the MIME type or enumerating a list of supported (registered) format handlers in the system. Each format handler provides a selection of functions that include, but is not limited to, the following.
1. Providing an application program interface (API) that: a. Performs playback and recording of multimedia content, including controlling functions such as seek, pause, resume, etc.; b. Sets and/or Gets audio and video control parameters; c. Handles asynchronous events from the -Media object.
2. Sending asynchronous media events via registered callback function.
3. Managing device multimedia rendering resources.
4. Managing a state machine that is extensible by derived classes.
[0056] FIG. 4 shows one embodiment of a state machine 400 managed by a format handler to render multimedia content, for example, the format handler 318. The initial state of the format handler is IDLE 402. Once the format handler is associated with an -Media object, the state of the format handler goes to READY 404. From the READY state 404, the format handler may proceed to either PLAY 406 or RECORD 408 states based on commands associated with the multimedia content. From the PLAY 406 and RECORD 408 states, the format handler may go to PLAY_PAUSE 410 or REC_PAUSE 412 states. From these states, it is also possible to resume the corresponding PLAY 406 and RECORD 408 states. The format handler may also STOP 414 and return to the READY 404 state.
[0057] Therefore, using the state machine 400, it is possible for each format handler to control the device's rendering resources to render multimedia applications or content (-Media object) that has been associated with that formal handler. In another embodiment, it is also possible for the format handler to implement a different state machine than the one shown in FIG. 4. Furthermore, in other embodiments, it is possible to define additional states, which may be used during the rendering process.
[0058] FIG. 5 shows one embodiment of a method 500 for rendering multimedia content in a portable device.
[0059] At block 502, a multimedia application or content is created using -Media constructs so that it may be rendered on a portable device. For example, application developers create -Media objects using the create media utility 324. The number of -Media objects and the capabilities, such as simultaneous playback or recording, are dependent on the device. All -Media objects follow the basic state machine shown in FIG. 4. In one embodiment, the following steps can be used to create and use an -Media object. [0060] 1. Create a media data structure and initialize it based on the media data source/sink. The AEEMediaData is defined as follows, typedef struct
{
AEECLSID clsData; // Type of media data void * pData; // Context sensitive data (see table) uint32 dwSize; // Context sensitive data (see table) } AEEMediaData;
[0061] 2. Initialize the members of the above structure based on the information in the following table.
Figure imgf000016_0001
[0062] At block 504, the multimedia content is downloaded to the portable device for rendering. For example, the application or content may be downloaded to the device via the wireless data network 108. The content may be rendered as streaming content, or stored in memory and rendered at a later time.
[0063] At block 506, a media data structure is created and initialized based on media source or sink characteristics included in the received content. For example, the media data structure is stored in the media data structure 326. In one embodiment, the media type is derived based on file extension, file content, or a signature included in the file. [0064] At block 508, an -Media object is created using the associated data structure.
For example, the create media utility 324 is used to create the -Media object. The
-Media object is returned in the ready state 404. [0065] At block 510, an optional step may be performed to register a notification function if it is desirable to received asynchronous events from the -Media object. [0066] At block 512, the -Media object is associated with a format handler and the multimedia application or content is rendered on the portable device. For example, the format handler may provide any of the functions of the state machine 400 to render to multimedia content. [0067] At block 514, after the content has been rendered and the -Media object is no longer needed, it is released.
IMPLEMENTATION EXAMPLE
[0068] The following is an implementation example to illustrate how in one embodiment an IMedia object is created. The example includes references to the corresponding blocks in the method of FIG. 5 and it is assumed that the runtime environment used by the portable device 102 is the BREW environment. Thus, "CApp" is an instance of a BREW applet global structure.
static void App_PlayMedia(CApp * pme)
{ int nRet;
AEEMediaData md;
// Create Media Data structure (FIG. 5-block 506) md.clsData = MMD_FILE_NAME; md.pData = (void *)Mmedia/midiJfmtLmid"; md.dwSize = 0;
// Create the -Media object and put in Ready state (FIG. 5-block 508) nRet = AEEMediaUtil_CreateMedia(pme->a.pIShell, &md, pme->m_pIMedia);
// If successful, register App_MediaNotify() as the registered callback for -Media events (FIG. 5-block 510) if (SUCCESS != nRet)
DisplayErrorDlg(pme, IDS_ERR_CREATEMEDIA); else if (SUCCESS != -MEDIA_RegisterNotify(pme->m_p_Media, App_MediaNotify, pme))
DisplayErrorDlg(pme, IDS_ERR_REGISTERNOTIFY); else if (SUCCESS != IMEDIA_Play(pme->m_pIMedia)) // Begin the playback (FIG. 5-block 512) DisplayErrorDlg(pme, IDS_ERR_PLAY) ;
[0069] In one or more embodiments included in the present invention, a multimedia system including methods and apparatus operates to render multimedia applications and content on a resource-limited portable device having an embedded controller. Accordingly, while one or more embodiments of the methods and apparatus have been illustrated and described herein, it will be appreciated that various changes can be made to the embodiments without departing from their spirit or essential characteristics. Therefore, the disclosures and descriptions herein are intended to be illustrative, but not limiting, of the scope of the invention, which is set forth in the following claims.
WE CLAIM:

Claims

1.. A method for rendering multimedia content in a portable device having an embedded processor, the portable device further comprising one or more rendering resources, and the method comprising: generating a multimedia object based on the multimedia content; associating a format handler with the multimedia object; and controlling a selected rendering resource using the format handler to render the multimedia content from the multimedia object.
2. The method of claim 1 , further comprising generating a multimedia data structure based on the multimedia content.
3. The method of claim 1, wherein the step of controlling comprises: implementing a state machine in the format handler to control the selected rendering resource; and rendering the multimedia content using the state machine in the format handler.
4. A multimedia system for rendering multimedia content in a portable device having an embedded processor, the portable device further comprising one or more rendering resources, and the multimedia system comprising: create media logic that operates to generate a multimedia object based on the multimedia content; selection logic that operates to associate a format handler with the multimedia object; and format handling logic that operates to control a selected rendering to render the multimedia content from the multimedia object.
5. The apparatus of claim 4, further comprising data structure logic to generate a multimedia data structure based on the multimedia content.
6. The apparatus of claim 5, wherein the format handling logic comprises: logic to implement a state machine in the format handler to control the selected rendering resource; and logic to render the multimedia content using the state machine in the formation handler.
7. A computer-readable medium containing computer-executable instructions for rendering multimedia content in a portable device having an embedded processor, the portable device further comprising one or more rendering resources, the instructions when executed perform a method, comprising: generating a multimedia object based on the multimedia content; associating a format handler with the multimedia object; and controlling a selected rendering resource using the format handler to render the multimedia content from the multimedia object.
8. The method of claim 7, further comprising generating a multimedia data structure based on the multimedia content.
9. The method of claim 7, wherein the step of controlling comprises: implementing a state machine in the format handler to control the selected rendering resource; and rendering the multimedia content using the state machine in the formation handler.
10. A multimedia system for rendering multimedia content in a portable device having an embedded processor, the portable device further comprising one or more rendering resources, and the multimedia system comprising: means for generating a multimedia object based on the multimedia content; means for associating a format handler with the multimedia object; and means for controlling a selected rendering resource using the format handler to render the multimedia content from the multimedia object.
11. The apparatus of claim 10, further comprising means for generating a multimedia data structure based on the multimedia content.
12. The apparatus of claim 10, wherein the means for controlling a selected rendering resource comprises: means for implementing a state machine in the format handler to control the selected rendering resource; and means for rendering the multimedia content using the state machine in the formation handler.
13. A multimedia system for rendering multimedia content in a portable device having an embedded processor, the portable device further comprising one or more rendering resources, and the multimedia system comprising: one or more format handlers that operate to control the one or more rendering resources in the portable device; and a creation utility that operates to create a multimedia object from the multimedia content and associate a selected format handler with the multimedia object, wherein the selected format handler renders the multimedia content from the multimedia object.
14. A method for rendering multimedia content in a portable device having an embedded processor, the portable device further comprising one or more rendering resources, and the method comprising: encoding the multimedia content with media constructs; transmitting the multimedia content to the portable device; generating a multimedia object based on the media constructs; associating a format handler with the multimedia object; and controlling a selected rendering resource using the format handler to render the multimedia content from the multimedia object.
PCT/US2003/017690 2002-06-04 2003-06-04 System for multimedia rendering in a portable device WO2003103212A2 (en)

Priority Applications (10)

Application Number Priority Date Filing Date Title
KR10-2004-7019567A KR20050010851A (en) 2002-06-04 2003-06-04 System for multimedia rendering in a portable device
JP2004510169A JP4943650B2 (en) 2002-06-04 2003-06-04 System for multimedia rendering on portable devices
IL16527803A IL165278A0 (en) 2002-06-04 2003-06-04 System for multimedia rendering in a portable device
CA002488470A CA2488470A1 (en) 2002-06-04 2003-06-04 System for multimedia rendering in a portable device
BRPI0311545-3A BR0311545A (en) 2002-06-04 2003-06-04 system for multimedia rendering on a portable device
NZ536703A NZ536703A (en) 2002-06-04 2003-06-04 System for multimedia rendering in a portable device
MXPA04012143A MXPA04012143A (en) 2002-06-04 2003-06-04 System for multimedia rendering in a portable device.
EP03756403A EP1522024A4 (en) 2002-06-04 2003-06-04 System for multimedia rendering in a portable device
AU2003251399A AU2003251399C1 (en) 2002-06-04 2003-06-04 System for multimedia rendering in a portable device
HK05109690.9A HK1075521A1 (en) 2002-06-04 2005-11-01 Method and system for multimedia rendering in a portable device

Applications Claiming Priority (6)

Application Number Priority Date Filing Date Title
US38594202P 2002-06-04 2002-06-04
US60/385,942 2002-06-04
US46553303P 2003-04-25 2003-04-25
US60/465,533 2003-04-25
US10/453,091 2003-06-02
US10/453,091 US20040083015A1 (en) 2002-06-04 2003-06-02 System for multimedia rendering in a portable device

Publications (2)

Publication Number Publication Date
WO2003103212A2 true WO2003103212A2 (en) 2003-12-11
WO2003103212A3 WO2003103212A3 (en) 2004-06-17

Family

ID=29716141

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2003/017690 WO2003103212A2 (en) 2002-06-04 2003-06-04 System for multimedia rendering in a portable device

Country Status (12)

Country Link
EP (1) EP1522024A4 (en)
JP (2) JP4943650B2 (en)
KR (1) KR20050010851A (en)
CN (1) CN100401281C (en)
AU (1) AU2003251399C1 (en)
BR (1) BR0311545A (en)
CA (1) CA2488470A1 (en)
HK (1) HK1075521A1 (en)
IL (1) IL165278A0 (en)
MX (1) MXPA04012143A (en)
NZ (1) NZ536703A (en)
WO (1) WO2003103212A2 (en)

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1755037A1 (en) * 2005-08-19 2007-02-21 Sony Corporation System-independent application state management
US7801560B2 (en) 2005-08-31 2010-09-21 Samsung Electronics Co., Ltd Accessory apparatus for mobile terminal for receiving and reproducing DMB data and method thereof
US9319448B2 (en) 2010-08-10 2016-04-19 Qualcomm Incorporated Trick modes for network streaming of coded multimedia data
US9380096B2 (en) 2006-06-09 2016-06-28 Qualcomm Incorporated Enhanced block-request streaming system for handling low-latency streaming
US9386064B2 (en) 2006-06-09 2016-07-05 Qualcomm Incorporated Enhanced block-request streaming using URL templates and construction rules
US9413803B2 (en) 2011-01-21 2016-08-09 Qualcomm Incorporated User input back channel for wireless displays
US9432433B2 (en) 2006-06-09 2016-08-30 Qualcomm Incorporated Enhanced block-request streaming system using signaling or block creation
US9582239B2 (en) 2011-01-21 2017-02-28 Qualcomm Incorporated User input back channel for wireless displays
US9628536B2 (en) 2006-06-09 2017-04-18 Qualcomm Incorporated Enhanced block-request streaming using cooperative parallel HTTP and forward error correction
US9787725B2 (en) 2011-01-21 2017-10-10 Qualcomm Incorporated User input back channel for wireless displays
US9917874B2 (en) 2009-09-22 2018-03-13 Qualcomm Incorporated Enhanced block-request streaming using block partitioning or request controls for improved client-side handling
US10135900B2 (en) 2011-01-21 2018-11-20 Qualcomm Incorporated User input back channel for wireless displays

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2257040A1 (en) * 2009-05-29 2010-12-01 Thomson Licensing Method and apparatus for distributing a multimedia content
CN102647629A (en) * 2012-04-27 2012-08-22 北京人民广播电台 Content playing method and content playing device
CN103777938A (en) * 2012-10-25 2014-05-07 百度在线网络技术(北京)有限公司 Playing method and device supporting multiple browsers
CN104618817B (en) * 2015-02-26 2018-07-17 北京奇艺世纪科技有限公司 A kind of control method and device of playback website video
US20170344523A1 (en) * 2016-05-25 2017-11-30 Samsung Electronics Co., Ltd Method and apparatus for presentation customization and interactivity

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6356529B1 (en) * 1999-08-12 2002-03-12 Converse, Ltd. System and method for rapid wireless application protocol translation
US6438575B1 (en) * 2000-06-07 2002-08-20 Clickmarks, Inc. System, method, and article of manufacture for wireless enablement of the world wide web using a wireless gateway
US6505160B1 (en) * 1995-07-27 2003-01-07 Digimarc Corporation Connected audio and other media objects
US20030156131A1 (en) * 2002-02-21 2003-08-21 Samir Khazaka Method and apparatus for emulating a mobile device
US6684088B1 (en) * 2000-03-01 2004-01-27 Axi Mobile Ltd. System and method for displaying electronic mail messages on a low bandwidth device

Family Cites Families (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6181713B1 (en) * 1997-10-27 2001-01-30 Sun Microsystems, Inc. Selectable depacketizer architecture
US6216152B1 (en) * 1997-10-27 2001-04-10 Sun Microsystems, Inc. Method and apparatus for providing plug in media decoders
JP2002529024A (en) * 1998-10-26 2002-09-03 ソニー エレクトロニクス インク Manage trick play of video data
KR100340169B1 (en) * 1999-09-27 2002-06-10 서성철 System and Method for Web Cataloging Dynamic Multimedia Using Java
CA2388095A1 (en) * 1999-10-22 2001-05-03 Activesky, Inc. An object oriented video system
JP2001125920A (en) * 1999-10-29 2001-05-11 Nippon Telegr & Teleph Corp <Ntt> Communication system and method for medium information and recording medium recorded with the method
JP2001168923A (en) * 1999-12-08 2001-06-22 Toshiba Corp Multimedia service system, multimedia conversion server, and multimedia terminal
US20010052933A1 (en) * 2000-01-12 2001-12-20 Nybo Larry Carl System and method for image capture, storage and retrieval
US20010037404A1 (en) * 2000-04-04 2001-11-01 Gudmundur Hafsteinsson System for wireless communication of data between a WEB server and a device using a wireless application protocol
US6891893B2 (en) * 2000-04-21 2005-05-10 Microsoft Corp. Extensible multimedia application program interface and related methods
US20020080143A1 (en) * 2000-11-08 2002-06-27 Morgan David L. Rendering non-interactive three-dimensional content
US20020103920A1 (en) * 2000-11-21 2002-08-01 Berkun Ken Alan Interpretive stream metadata extraction
US7139470B2 (en) * 2001-08-17 2006-11-21 Intel Corporation Navigation for MPEG streams

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6505160B1 (en) * 1995-07-27 2003-01-07 Digimarc Corporation Connected audio and other media objects
US6356529B1 (en) * 1999-08-12 2002-03-12 Converse, Ltd. System and method for rapid wireless application protocol translation
US6684088B1 (en) * 2000-03-01 2004-01-27 Axi Mobile Ltd. System and method for displaying electronic mail messages on a low bandwidth device
US6438575B1 (en) * 2000-06-07 2002-08-20 Clickmarks, Inc. System, method, and article of manufacture for wireless enablement of the world wide web using a wireless gateway
US20030156131A1 (en) * 2002-02-21 2003-08-21 Samir Khazaka Method and apparatus for emulating a mobile device

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See also references of EP1522024A2 *

Cited By (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1755037A1 (en) * 2005-08-19 2007-02-21 Sony Corporation System-independent application state management
US7801560B2 (en) 2005-08-31 2010-09-21 Samsung Electronics Co., Ltd Accessory apparatus for mobile terminal for receiving and reproducing DMB data and method thereof
US8442584B2 (en) 2005-08-31 2013-05-14 Samsung Electronics Co., Ltd Accessory apparatus of mobile terminal for receiving and reproducing DMB data and method thereof
US9628536B2 (en) 2006-06-09 2017-04-18 Qualcomm Incorporated Enhanced block-request streaming using cooperative parallel HTTP and forward error correction
US9386064B2 (en) 2006-06-09 2016-07-05 Qualcomm Incorporated Enhanced block-request streaming using URL templates and construction rules
US9432433B2 (en) 2006-06-09 2016-08-30 Qualcomm Incorporated Enhanced block-request streaming system using signaling or block creation
US9380096B2 (en) 2006-06-09 2016-06-28 Qualcomm Incorporated Enhanced block-request streaming system for handling low-latency streaming
US11477253B2 (en) 2006-06-09 2022-10-18 Qualcomm Incorporated Enhanced block-request streaming system using signaling or block creation
US9917874B2 (en) 2009-09-22 2018-03-13 Qualcomm Incorporated Enhanced block-request streaming using block partitioning or request controls for improved client-side handling
US11770432B2 (en) 2009-09-22 2023-09-26 Qualcomm Incorporated Enhanced block-request streaming system for handling low-latency streaming
US11743317B2 (en) 2009-09-22 2023-08-29 Qualcomm Incorporated Enhanced block-request streaming using block partitioning or request controls for improved client-side handling
US10855736B2 (en) 2009-09-22 2020-12-01 Qualcomm Incorporated Enhanced block-request streaming using block partitioning or request controls for improved client-side handling
US9456015B2 (en) 2010-08-10 2016-09-27 Qualcomm Incorporated Representation groups for network streaming of coded multimedia data
US9319448B2 (en) 2010-08-10 2016-04-19 Qualcomm Incorporated Trick modes for network streaming of coded multimedia data
US10135900B2 (en) 2011-01-21 2018-11-20 Qualcomm Incorporated User input back channel for wireless displays
US10382494B2 (en) 2011-01-21 2019-08-13 Qualcomm Incorporated User input back channel for wireless displays
US9787725B2 (en) 2011-01-21 2017-10-10 Qualcomm Incorporated User input back channel for wireless displays
US10911498B2 (en) 2011-01-21 2021-02-02 Qualcomm Incorporated User input back channel for wireless displays
US9582239B2 (en) 2011-01-21 2017-02-28 Qualcomm Incorporated User input back channel for wireless displays
US9413803B2 (en) 2011-01-21 2016-08-09 Qualcomm Incorporated User input back channel for wireless displays

Also Published As

Publication number Publication date
CA2488470A1 (en) 2003-12-11
MXPA04012143A (en) 2005-04-19
NZ536703A (en) 2007-11-30
CN100401281C (en) 2008-07-09
AU2003251399A1 (en) 2003-12-19
EP1522024A4 (en) 2007-03-28
JP2010288301A (en) 2010-12-24
KR20050010851A (en) 2005-01-28
HK1075521A1 (en) 2005-12-16
AU2003251399B2 (en) 2009-07-23
JP4943650B2 (en) 2012-05-30
AU2003251399C1 (en) 2009-12-17
CN1659536A (en) 2005-08-24
IL165278A0 (en) 2005-12-18
WO2003103212A3 (en) 2004-06-17
BR0311545A (en) 2007-04-27
EP1522024A2 (en) 2005-04-13
JP2005528849A (en) 2005-09-22

Similar Documents

Publication Publication Date Title
US20040083015A1 (en) System for multimedia rendering in a portable device
JP2010288301A (en) System for multimedia rendering in portable device
US20040212687A1 (en) System for controlling a camera resource in a portable device
JP5646687B2 (en) Adaptive streaming for on-demand wireless services
KR100954346B1 (en) Method, system, apparatus ? computer program product for enabling the pre-download of media objects
US20090225093A1 (en) Buffers for display acceleration
JP2005518015A (en) Middleware service layer for platform systems for mobile terminals
JP2023506936A (en) MULTI-SCREEN COOPERATION METHOD AND SYSTEM AND ELECTRONIC DEVICE
US20070204224A1 (en) System and method for storing and accessing data files at wireless devices
RU2316907C2 (en) System for reproduction of multimedia in portable device
JP2005518116A (en) Mobile multimedia engine
US7114153B2 (en) Method and apparatus for continuation-passing in a virtual machine
US20090228495A1 (en) File system cloning between a target device and a host device
RU2352977C2 (en) System for control of chamber resource in portable device
EP1463992A1 (en) Host extensible wireless application interface
KR100627819B1 (en) Method for Controlling Application by Using Functions of WAP Browser
CN101911003B (en) Information processing apparatus and program
EP1584028A2 (en) Host extensible wireless application interface

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 1200500004

Country of ref document: VN

AK Designated states

Kind code of ref document: A2

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NI NO NZ OM PH PL PT RO RU SC SD SE SG SK SL TJ TM TN TR TT TZ UA UG UZ VC VN YU ZA ZM ZW

AL Designated countries for regional patents

Kind code of ref document: A2

Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IT LU MC NL PT RO SE SI SK TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
WWE Wipo information: entry into national phase

Ref document number: 165278

Country of ref document: IL

WWE Wipo information: entry into national phase

Ref document number: 536703

Country of ref document: NZ

WWE Wipo information: entry into national phase

Ref document number: 2003251399

Country of ref document: AU

WWE Wipo information: entry into national phase

Ref document number: 1020047019567

Country of ref document: KR

WWE Wipo information: entry into national phase

Ref document number: 2488470

Country of ref document: CA

Ref document number: 2004510169

Country of ref document: JP

Ref document number: 2728/CHENP/2004

Country of ref document: IN

WWE Wipo information: entry into national phase

Ref document number: PA/a/2004/012143

Country of ref document: MX

WWE Wipo information: entry into national phase

Ref document number: 20038130858

Country of ref document: CN

WWE Wipo information: entry into national phase

Ref document number: 2003756403

Country of ref document: EP

ENP Entry into the national phase

Ref document number: 2004139098

Country of ref document: RU

Kind code of ref document: A

WWP Wipo information: published in national office

Ref document number: 1020047019567

Country of ref document: KR

WWP Wipo information: published in national office

Ref document number: 2003756403

Country of ref document: EP

ENP Entry into the national phase

Ref document number: PI0311545

Country of ref document: BR