(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-12-06
(45)【発行日】2024-12-16
(54)【発明の名称】受信装置およびプログラム
(51)【国際特許分類】
H04N 21/435 20110101AFI20241209BHJP
【FI】
H04N21/435
(21)【出願番号】P 2020144463
(22)【出願日】2020-08-28
【審査請求日】2023-07-21
(31)【優先権主張番号】P 2019157273
(32)【優先日】2019-08-29
(33)【優先権主張国・地域又は機関】JP
(31)【優先権主張番号】P 2019194499
(32)【優先日】2019-10-25
(33)【優先権主張国・地域又は機関】JP
(73)【特許権者】
【識別番号】000004352
【氏名又は名称】日本放送協会
(73)【特許権者】
【識別番号】399060908
【氏名又は名称】一般財団法人NHK財団
(74)【代理人】
【識別番号】100141139
【氏名又は名称】及川 周
(74)【代理人】
【識別番号】100171446
【氏名又は名称】高田 尚幸
(74)【代理人】
【識別番号】100114937
【氏名又は名称】松本 裕幸
(74)【代理人】
【識別番号】100171930
【氏名又は名称】木下 郁一郎
(72)【発明者】
【氏名】藤沢 寛
(72)【発明者】
【氏名】大亦 寿之
(72)【発明者】
【氏名】広中 悠樹
(72)【発明者】
【氏名】藤井 亜里砂
(72)【発明者】
【氏名】平松 和茂
(72)【発明者】
【氏名】武智 秀
【審査官】鈴木 順三
(56)【参考文献】
【文献】特開2016-027743(JP,A)
【文献】特開2013-009340(JP,A)
【文献】国際公開第2015/076178(WO,A1)
(58)【調査した分野】(Int.Cl.,DB名)
H04N 21/00 - 21/858
(57)【特許請求の範囲】
【請求項1】
放送信号を受信する受信部と、
前記受信部が受信する前記放送信号の放送サービスを選局する選局部と、
受信した前記放送信号から放送リソースを抽出する抽出部と、
アプリケーションプログラムを実行させるアプリケーション実行部と、
前記アプリケーション実行部で実行される前記アプリケーションプログラムの稼働を管理するアプリケーション稼働管理部と、
を備える受信装置であって、
前記アプリケーションプログラムは、
特定の放送サービスを選局中であるか否かに依らず動作することができるアプリケーションプログラムである放送非依存マネージドアプリケーションを含み、
前記アプリケーション稼働管理部は、前記
放送非依存マネージドアプリケーションが稼働する際に前記放送リソースにアクセスすることを禁止する、
受信装置。
【請求項2】
放送信号を受信する受信部と、
前記受信部が受信する前記放送信号の放送サービスを選局する選局部と、
受信した前記放送信号から放送リソースを抽出する抽出部と、
アプリケーションプログラムを実行させるアプリケーション実行部と、
を備えるコンピューターを、
請求項
1に記載の受信装置として機能させるためのプログラム。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、受信装置およびプログラムに関する。
【背景技術】
【0002】
テレビの放送番組と、テレビ受像機上で稼働するアプリケーションプログラムと、通信ネットワークを介して配信される映像等のコンテンツとがシームレスに連携することにより、多様なサービスが展開されることが期待される。
【0003】
非特許文献1の第6.1節(第14ページから)には、放送通信連携システムのアプリケーションモデルが記載されている。第6.1.1節には、アプリケーションの分類が記載されている。
図6-1には、アプリケーション間の状態遷移が記載されている。第6.1.2節には、アプリケーションバウンダリと放送リソースアクセスについて記載されている。
【先行技術文献】
【非特許文献】
【0004】
【文献】IPTV規定「放送通信連携システム仕様」,IPTVFJ STD-0010 2.2版,2018年9月21日,一般社団法人 IPTVフォーラム(IPTV Forum Japan)
【発明の概要】
【発明が解決しようとする課題】
【0005】
しかしながら、従来の技術では、ハイブリッドキャストの仕組みにおける放送マネージドアプリと放送マネージドアプリ以外のアプリとの間で、双方向にスムーズな遷移をすることができないという問題があった。例えば、放送マネージドアプリ以外のアプリが通信ネットワークで配信されるコンテンツを再生する機能を提供するアプリである場合など、上記のアプリ間のスムーズな遷移が望まれる。また、このとき、放送マネージドアプリ以外のアプリを用いる理由は、そのようなアプリが特定の放送サービスに従属することが好ましくないためである。
【0006】
本発明は、上記の課題認識に基づいて行なわれたものであり、特定の放送サービスに従属することのない独立のアプリと、放送マネージドアプリとの間で、スムーズに双方向の遷移を行えるようにすることのできる受信装置およびプログラムを提供しようとするものである。
【課題を解決するための手段】
【0007】
[1]上記の課題を解決するため、本発明の一態様による受信装置は、放送信号を受信する受信部と、前記受信部が受信する前記放送信号の放送サービスを選局する選局部と、受信した前記放送信号から放送リソースを抽出する抽出部と、アプリケーションプログラムを実行させるアプリケーション実行部と、前記アプリケーション実行部で実行される前記アプリケーションプログラムの稼働を管理するアプリケーション稼働管理部と、を備える受信装置であって、前記アプリケーションプログラムは、放送独立型アプリケーションプログラムを含み、前記アプリケーション稼働管理部は、前記放送独立型アプリケーションプログラムが稼働する際に前記放送リソースにアクセスすることを禁止する、受信装置である。
【0008】
[2]また、本発明の一態様は、上記の受信装置において、前記受信装置と連携動作する連携端末装置からの、前記放送サービスの識別情報と前記アプリケーションプログラムの識別情報とを指定した要求に基づいて、指定された前記放送サービスを選局するよう前記選局部を制御するとともに、指定された前記アプリケーションプログラムを起動するよう前記アプリケーション稼働管理部を制御する外部起動実行部、をさらに備えるものである。
【0009】
[3]また、本発明の一態様は、上記の受信装置において、前記外部起動実行部は、指定された前記放送サービスが予め定められた値である場合には、前記放送サービスの選局状態を解除するよう前記選局部を制御するものである。
【0010】
[4]また、本発明の一態様は、上記の受信装置において、前記アプリケーション稼働管理部は、受信装置で同時に実行可能なアプリケーションプログラムの数の上限が1の場合であって、前記外部起動実行部によって指定された前記アプリケーションプログラムを起動した場合にはアプリケーションプログラムの数が前記上限を超えることになってしまう場合には、既に稼働していたアプリケーションプログラムを終了させる制御を行う、ものである。
【0011】
[5]また、本発明の一態様は、上記の受信装置において、前記外部起動実行部は、指定された前記放送サービスの識別情報と前記アプリケーションプログラムの識別情報との間の整合性を、外部のサーバー装置に問い合わせることによって確認し、整合性が確認された場合にのみ、前記指定された前記放送サービスを選局するよう前記選局部を制御するとともに、前記指定された前記アプリケーションプログラムを起動するよう前記アプリケーション稼働管理部を制御する、ものである。
【0012】
[6]また、本発明の一態様は、上記の受信装置において、前記外部起動実行部は、指定された前記放送サービスが予め定められた値である場合には、前記放送サービスの選局状態を解除するよう前記選局部を制御するものである。
【0013】
[7]また、本発明の一態様は、上記の受信装置において、入力される映像および音声を提示する提示部、をさらに備え、前記抽出部は、抽出した前記放送リソースに含まれる映像および音声を前記提示部に入力するものであり、前記放送独立型アプリケーションプログラムは、通信ネットワークを介して外部装置からコンテンツデータを受信し、受信した前記コンテンツデータに含まれる映像および音声を前記提示部に入力する機能を持つ、ものである。
【0014】
[8]また、本発明の一態様は、上記の受信装置において、前記選局部は、前記放送独立型アプリケーションプログラムまたは特定の前記放送サービスの放送信号に基づいて起動される放送マネージドアプリケーションプログラム、による選局指示にしたがって前記放送サービスを選局するものであり、前記アプリケーション稼働管理部は、前記放送独立型アプリケーションプログラムが前記選局指示を行った場合に、当該前記放送独立型アプリケーションプログラムを終了させる、というものである。
【0015】
[9]また、本発明の一態様は、上記の受信装置において、前記選局部は、選局可能なメディアの情報を保持するものであり、前記放送独立型アプリケーションプログラムは、所定のアプリケーションプログラムインターフェースを介して、前記選局部が保持する選局可能なメディアの情報を取得する、ものである。
【0016】
[10]また、本発明の一態様は、上記の受信装置において、前記選局部は、前記メディアに対応付けて選局可能なチャンネルの情報を保持するものであり、前記放送独立型アプリケーションプログラムは、所定のアプリケーションプログラムインターフェースを介して、前記選局部が保持する、すべての選局可能なチャンネルの情報、または特定のメディアの選局可能なチャンネルの情報、を取得する、ものである。
【0017】
[11]また、本発明の一態様は、放送信号を受信する受信部と、前記受信部が受信する前記放送信号の放送サービスを選局する選局部と、受信した前記放送信号から放送リソースを抽出する抽出部と、アプリケーションプログラムを実行させるアプリケーション実行部と、を備えるコンピューターを、上記の[1]から[10]までのいずれかに記載の受信装置として機能させるためのプログラムである。
【0018】
[参考例1]また、一態様は、上記の受信装置において、前記アプリケーション稼働管理部は、受信装置で同時に実行可能なアプリケーションプログラムの数に上限が設けられている場合であって、特定の前記放送サービスのみの前記放送信号に基づいて起動される放送マネージドアプリケーションプログラムから前記放送独立型アプリケーションプログラムへの遷移を行う際に、前記上限が1である場合には、前記放送マネージドアプリケーションプログラムを終了させてから前記放送独立型アプリケーションプログラムを起動する制御を行うものであり、前記放送独立型アプリケーションプログラムから前記放送マネージドアプリケーションプログラムへの遷移を行う際に、前記上限が1である場合には、前記アプリケーション稼働管理部は、前記放送独立型アプリケーションプログラムを終了させてから前記放送マネージドアプリケーションプログラムを起動する制御を行うものである。
【0019】
[参考例2]また、一態様は、上記の受信装置において、前記外部起動実行部は、前記アプリケーションプログラムを起動するための要求を受ける際に要求元のアプリケーションプログラムの識別情報である要求元識別情報または前記要求元のアプリケーションプログラムの種別を表す要求元種別情報の少なくともいずれかの情報をパラメーターとして受け取り、指定された前記アプリケーションプログラムを起動するよう前記アプリケーション稼働管理部を制御する際に前記パラメーターを前記アプリケーション稼働管理部に渡し、前記アプリケーション稼働管理部は、前記外部起動実行部から渡された前記パラメーターを、起動対象である前記アプリケーションプログラムに渡すものであり、前記要求元種別情報は、当該受信装置で稼働する放送独立型アプリケーションプログラムであるか前記連携端末装置で稼働するアプリケーションプログラムであるかを少なくとも区別する情報である、というものである。
【0020】
[参考例3]また、一態様は、上記の受信装置において、アプリケーションプログラムの起動命令を受信した際に、当該アプリケーションプログラム用のアプリケーション情報テーブルに基づいて前記アプリケーションプログラムの種別を判定するアプリケーション情報テーブル管理部、をさらに備える。
【0021】
[参考例4]また、一態様による受信装置は、放送信号を受信する受信部と、前記受信部が受信する前記放送信号の放送サービスを選局する選局部と、受信した前記放送信号から放送リソースを抽出する抽出部と、アプリケーションプログラムを実行させるアプリケーション実行部と、前記アプリケーション実行部で実行される前記アプリケーションプログラムの稼働を管理するアプリケーション稼働管理部と、前記アプリケーション実行部で実行させる前記アプリケーションプログラムの起動命令を受信した際に、当該アプリケーションプログラム用のアプリケーション情報テーブルに基づいて前記アプリケーションプログラムの種別を判定し、その種別を前記アプリケーション稼働管理部に通知するアプリケーション情報テーブル管理部とを備えるものである。
【0022】
[参考例5]また、一態様は、上記の受信装置において、前記アプリケーション情報テーブル管理部は、前記アプリケーション情報テーブル内の、当該アプリケーションプログラムを提供する組織を識別する情報に基づいて、前記種別を判定するものである。
【0023】
[参考例6]また、一態様は、上記の受信装置において、前記アプリケーション情報テーブル管理部は、前記アプリケーション情報テーブル内の、当該アプリケーションプログラムの種別を識別する情報に基づいて、前記種別を判定するものである。
【0024】
[参考例7]また、一態様は、上記の受信装置において、前記アプリケーション情報テーブル管理部は、前記アプリケーション情報テーブル内のサービスバウンド情報に基づいて、前記種別を判定するものである。
【0025】
[参考例8]また、一態様は、上記の受信装置において、前記アプリケーション情報テーブル管理部は、前記アプリケーションプログラムの起動方法と前記種別とが整合しているか否かを判定し、整合している場合には当該アプリケーションプログラムの起動を許可し、整合していない場合には当該アプリケーションプログラムの起動を中止させるものである。
【0026】
[参考例9]また、一態様は、上記の受信装置において、前記アプリケーション情報テーブル管理部が判定した前記種別に応じて、前記アプリケーション実行部において実行中の前記アプリケーションプログラムが要求したリソースへのアクセスを許可するか否かを制御するリソースアクセス制御部、をさらに具備するものである。
【発明の効果】
【0027】
本発明によれば、受信装置は、放送独立型のアプリを稼働させることができる。また、受信装置は、そのような放送独立型のアプリから、放送マネージドアプリや放送サービスに、スムーズな遷移を行わせることができる。
【図面の簡単な説明】
【0028】
【
図1】本発明の第1実施形態による受信装置の概略機能構成を示すブロック図である。
【
図2】同実施形態によるアプリケーション稼働管理部のさらに詳細な機能構成を示すブロック図である。
【
図3】同実施形態による受信装置における、放送マネージドアプリと放送独立型アプリとの間の遷移の方法の例を示す概略図である。
【
図4】同実施形態による受信装置100を利用して実現されるコンテンツ提示システムの稼働例を示す概略図である。
【
図5】第2実施形態による受信装置の概略機能構成を示すブロック図である。
【
図6】同実施形態による受信装置が稼働するシステムの全体的な装置構成を示すブロック図である。
【
図7】同実施形態によりアプリの種別を判定する第1の方法のための、AIT(アプリケーション情報テーブル)の構成例(1/2)を示す概略図である。
【
図8】同実施形態によりアプリの種別を判定する第1の方法のための、AITの構成例(2/2)を示す概略図である。
【
図9】同実施形態によりアプリの種別を判定する第2の方法のための、AITの構成例(1/2)を示す概略図である。
【
図10】同実施形態によりアプリの種別を判定する第2の方法のための、AITの構成例(2/2)を示す概略図である。
【
図11】同実施形態によりアプリの種別を判定する第3の方法のための、AITの構成例(1/2)を示す概略図である。
【
図12】同実施形態によりアプリの種別を判定する第3の方法のための、AITの構成例(2/2)を示す概略図である。
【
図13】第3実施形態による受信装置の概略機能構成を示すブロック図である。
【
図14】第4実施形態による受信装置の概略機能構成を示すブロック図である。
【
図15】同実施形態において受信装置上で稼働する放送独立型アプリケーションが放送を選局する際の動作手順の例を示すフローチャートである。
【発明を実施するための形態】
【0029】
次に、本発明の実施形態について、図面を参照しながら説明する。なお、以下において、「アプリケーションプログラム」のことを「アプリ」と呼ぶ場合がある。
【0030】
[第1実施形態]
図1は、本実施形態による受信装置の概略機能構成を示すブロック図である。受信装置100(「受信機」とも呼ばれる)は、放送信号を受信して、受信した放送信号に基づき、映像や音声を提示する。受信装置100は、いわゆるテレビ受像機である。また、受信装置100は、アプリを呼び出して実行する機能を有する。受信装置100において実行されるアプリは、所定のAPI(アプリケーションプログラミングインターフェース)を介して、通信ネットワークを介して外部と通信したり、画像あるいは映像等を画面に表示させたりすることができる。図示するように、受信装置100は、受信部1と、復調部2と、復号部3と、提示部4と、選局部5と、アプリケーション実行部200と、アプリケーション記憶部201と、アプリケーション稼働管理部210と、外部起動実行部220と、端末連携部221と、要求生成部222と、通信機能部240と、を含んで構成される。これらの各機能部は、例えば、電子回路を用いて実現される。また、各機能部は、必要に応じて、半導体メモリーや磁気ハードディスク装置などといった記憶手段を内部に備えてよい。また、ここに列挙した各機能、またはその一部の機能を、コンピューターおよびソフトウェア(プログラム)によって実現するようにしてもよい。各部の機能は、次に説明する通りである。
【0031】
受信部1は、テレビの放送信号を受信する。放送信号は、空中を、あるいは金属ケーブルや光ファイバーケーブル等の伝送媒体を伝搬する。
復調部2は、受信部1が受信した放送信号を復調する。
復号部3は、復調部2が復調した信号を基に、復号処理を行い、放送リソースを抽出する。放送リソースとは、映像や、音声や、テキスト等のコンテンツのデータである。
なお、復調部2と復号部3とをあわせて「抽出部」と呼んでもよい。つまり、抽出部は、受信した放送信号から放送リソースを抽出する。抽出部(復調部2および復号部3)は、抽出した放送リソースに含まれる映像および音声を提示部4に入力するものである。
【0032】
提示部4は、コンテンツを提示する。コンテンツは、映像や音声から成る。提示部4は、映像を表示装置(例えば、液晶ディスプレイや有機ELディスプレイ等)に表示する。
提示部4は、音声を、スピーカーやイヤフォン等から出力する。なお、提示部4が提示する映像や音声は、復号部3やアプリケーション実行部200から渡される。
【0033】
選局部5は、受信部1が受信する放送信号の放送サービス(チャンネル)を選局する。
選局部5は、例えばテレビリモコン装置からの信号に基づいて選局する。あるいは、選局部5は、後述する外部起動実行部220や、アプリケーション稼働管理部210からの制御に基づいて選局してもよい。
【0034】
アプリケーション実行部200は、アプリケーションプログラムを実行させる。具体的には、アプリケーション実行部200は、放送リソースや受信機リソースにアクセスするための拡張APIを備えたHTML5ブラウザーである。
【0035】
アプリケーション記憶部201は、アプリケーションプログラムを記憶する。
【0036】
アプリケーション稼働管理部210は、アプリケーションプログラムの稼働を管理する。アプリケーション稼働管理部210は、例えば、アプリケーション記憶部201からアプリケーションプログラムのコードを読み出して、アプリケーション実行部200で実行させる。つまり、アプリケーション稼働管理部210は、アプリケーションプログラムを起動する。アプリケーションプログラムの起動においては、起動の可否を判定する認証等を行うこともある。また、アプリケーション稼働管理部210は、稼働中のアプリケーションプログラムを終了させる。また、アプリケーション稼働管理部210は、アプリケーションプログラムの稼働状況を管理し、制御する。例えば、アプリケーション稼働管理部210は、稼働中のアプリケーションプログラムが受信装置100内の特定のリソース(例えば、放送リソース)にアクセスする(つまりリソースを取得する)ことを、許可したり、禁止したりするといった管理を行う。稼働中のアプリケーションプログラムは、アプリケーション稼働管理部210による許可あるいは不許可(禁止)の制御の下で、各種リソースにアクセスしたり、利用したりする。
【0037】
なお、アプリケーションプログラムは、種類として、放送独立型アプリケーションプログラムを含む。放送独立型アプリケーションプログラムは、特定の放送サービスのみの放送信号に基づいて起動されるものではない。放送独立型アプリケーションプログラムは、言い換えれば、特定の前記放送サービスの前記放送信号以外に基づいて起動されるものである。アプリケーション稼働管理部210は、放送独立型アプリケーションプログラムが稼働する際に放送リソースにアクセスすることを禁止する。
【0038】
放送独立型アプリケーションプログラムは、一例として、通信ネットワークを介して外部装置からコンテンツデータを受信し、受信した前記コンテンツデータに含まれる映像および音声を提示部4に入力する機能を持つ。つまり、ある種の放送独立型アプリケーションプログラムは、ネット配信される映像および音声のコンテンツの再生手段として、受信装置100を機能させる。
【0039】
外部起動実行部220は、受信装置のアプリケーション実行環境外に実装された外部起動ロンチャーにより、連携端末装置から受信装置100に対するアプリケーションの起動を制御する。なお、後述するように、外部起動実行部220は、連携端末装置になり代わって要求を生成する要求生成部222からの要求等にも対応する。具体的には、外部起動実行部220は、受信装置100と連携動作する連携端末装置(不図示)からの、放送サービスの識別情報とアプリケーションプログラムの識別情報とを指定した要求に基づいて、指定された放送サービスを選局するよう選局部5を制御するとともに、指定されたアプリケーションプログラムを起動するようアプリケーション稼働管理部210を制御する。
なお、放送サービスの識別情報としては、original_network_id、transport_stream_id、service_idの3種類の識別子の組などが該当する。また、アプリケーションプログラムの識別情報としては、アプリケーションのロケーションを示すAIT(Application Information Table、アプリケーション情報テーブル)のURLや、アプリケーションの提供者が付与するappId自身、あるいは、アプリケーションの提供者を識別するorgIdとappIdの組などが該当する。
【0040】
端末連携部221は、連携端末装置と、外部起動実行部220との間を仲介する。連携端末装置から外部起動実行部220への要求は、まず端末連携部221によって受け付けられ、外部起動実行部220に転送される。
【0041】
要求生成部222は、稼働している放送独立型アプリケーションプログラムから指定された放送サービスの識別情報とアプリケーションプログラムの識別情報とを用いて、連携端末装置になり代わって、指定された放送サービスの識別情報とアプリケーションプログラムの識別情報とを指定した外部起動実行部220に対する要求(選局およびアプリ起動の要求)を生成する。要求生成部222は、生成した要求を、外部起動実行部220に渡す。
【0042】
通信機能部240は、受信装置100の各部が、外部と通信するための機能を提供する。受信装置100は、例えば、無線通信を介して、インターネットプロトコルを用いて、外部の装置と相互に通信する。
【0043】
図2は、アプリケーション稼働管理部のさらに詳細な機能構成を示すブロック図である。図示するように、アプリケーション稼働管理部210は、放送マネージドアプリ管理部211と、放送外マネージドアプリ管理部212と、放送独立型アプリ管理部213と、一般アプリ管理部214と、を含んで構成される。各部の機能は、次に説明する通りである。放送マネージドアプリ(放送マネージドアプリケーションプログラム)、放送外マネージドアプリ、放送独立型アプリ、一般アプリといったアプリの種類は、放送と通信とを連携するための枠組みであるハイブリッドキャストにおける分類である。なお、放送独立型アプリは、従来技術においては存在しない。
【0044】
放送マネージドアプリ管理部211は、放送マネージドアプリの稼働を管理する。放送マネージドアプリは、放送信号に含まれる制御信号に基づいて制御される。放送マネージドアプリは、そういった制御信号に含まれる起動の指示によって起動される。また、稼働中の放送マネージドアプリは、制御信号に含まれる終了の指示によって終了させられる。
放送マネージドアプリは、放送サービスに従属するアプリであり、受信装置100がその放送サービスを受信している(選局している)状態においてのみ、動作する。なお、放送マネージドアプリは、放送リソースへのアクセスすることを許可される。つまり、放送マネージドアプリ管理部211は、放送マネージドアプリの稼働を管理し、放送マネージドアプリが放送リソースにアクセスすることを許可する。
【0045】
放送外マネージドアプリ管理部212は、放送外マネージドアプリの稼働を管理する。
放送外マネージドアプリは、放送信号以外の手段に基づいて、起動されたり、終了されたりする。放送外マネージドアプリは、放送信号以外で行うアプリケーション認証の手段に基づいて、放送リソースへのアクセスが許可される。つまり、放送外マネージドアプリ管理部212は、アプリケーション認証の結果に基づき、認証が正しく行われる場合にのみ放送外マネージドアプリが放送リソースにアクセスすることを許可する。放送外マネージドアプリ管理部212は、その他の場合には、放送外マネージドアプリが放送リソースにアクセスすることを禁止する制御を行う。
【0046】
放送独立型アプリ管理部213は、放送独立型アプリの稼働を管理する。放送独立型アプリは、放送サービスから独立なアプリである。つまり、放送独立型アプリは、特定の放送サービスを受信中(選局中)であるか否かに依らず、動作することができる。放送独立型アプリは、例えば、テレビリモコン装置からのリモコン信号や、受信装置100と連携動作する連携端末装置からの要求信号等に基づいて、起動されたり終了されたりする。放送独立型アプリ管理部213は、放送リソースにアクセスすることが許可されていない。
つまり、放送独立型アプリ管理部213は、放送独立型アプリが放送リソースにアクセスすることを禁止するような制御を行う。
【0047】
放送独立型アプリが放送サービスから独立であることをさらに説明すると、次の通りである。放送独立型アプリは、特定の放送局(放送事業者)からの信号のみによって制御されるものではない。放送独立型アプリは、任意のタイミングで、例えばユーザーの操作に基づき、起動され得る。あるいは、放送独立型アプリは、任意のタイミングで、他のアプリから呼び出される形で起動されてもよい。つまり、放送独立型アプリの稼働は、特定の放送局によって縛られるものではない。
【0048】
なお、放送独立型アプリは、「放送独立型アプリケーションプログラム」、「インデペンデントアプリ」、「インデペンデントアプリケーションプログラム」、「IndependentApp」、「放送非依存マネージドアプリケーション」などとも呼ばれる。あるいは、放送独立型アプリは、他の呼び方で呼ばれる場合もある。
【0049】
一般アプリ管理部214は、一般アプリの稼働を管理する。
【0050】
アプリの種別ごとの特徴は、下の表1に記載する通りである。
【0051】
【0052】
ここで、放送局による起動・終了のトリガーとは、放送信号によってアプリの起動や終了が制御されることを意味する。また、ユーザーによる起動・終了のトリガーとは、ユーザーの操作(例えば、テレビリモコンの操作や、テレビと連携する連携端末(より具体的には、スマートフォンや、タブレット端末や、ウェアラブル端末等)の操作)によってアプリの起動や終了が制御されることを意味する。また、放送リソースへのアクセスが可または不可とは、アプリが、放送信号によって伝達されるリソースを参照することが許可されるか否かを表す。放送信号によって伝達されるリソースとは、典型的には、映像や、音声や、字幕等のテキストである。
【0053】
上の表に示すように、放送マネージドアプリの起動および終了のトリガーは、放送局の送信設備から送信される放送信号によって与えられる。また、放送マネージドアプリは、放送リソースにアクセスすることが許可される。また、放送マネージドアプリは、ハイブリッドキャストアプリに関連付けることが許可される。
【0054】
また、放送外マネージドアプリの起動および終了のトリガーは、ユーザーによる操作等に基づく制御信号によって与えられる。また、放送外マネージドアプリは、放送リソースにアクセスすることが条件付きで許可される。また、放送外マネージドアプリは、ハイブリッドキャストアプリに関連付けることが許可される。
【0055】
また、一般アプリの起動および終了のトリガーは、ユーザーによる操作等に基づく制御信号によって与えられる。また、一般アプリは、放送リソースにアクセスすることが許可されない。また、一般アプリは、ハイブリッドキャストアプリに関連付けることが許可されない。
【0056】
放送独立型アプリの稼働管理については、次の通りである。即ち、放送独立型アプリの起動および終了のトリガーは、ユーザーによる操作等に基づく制御信号によって与えられる。また、放送独立型アプリは、放送リソースにアクセスすることが許可されない。また、放送独立型アプリは、ハイブリッドキャストアプリに関連付けることができる。
【0057】
アプリケーション稼働管理部210は、アプリの種別に応じて、表1に示したアプリの稼働の制御を行う。つまり、具体的には、放送マネージドアプリ管理部211や、放送外マネージドアプリ管理部212や、放送独立型アプリ管理部213や、一般アプリ管理部214は、それぞれ、放送マネージドアプリや、放送外マネージドアプリや、放送独立型アプリや、一般アプリの稼働の、起動および終了を制御したり、放送リソースへのアクセスの許可または不許可を制御したり、ハイブリッドキャストアプリとの関連付け(紐付け)の許可または不許可を制御したりする。
【0058】
受信装置100において同時に実行可能なアプリの数が限られている場合には、アプリケーション稼働管理部210は、予め受信装置100に設定した優先度や放送信号で指示する優先度に従って優先度の低いアプリケーションを終了する制御を実行する。
つまり、アプリケーション稼働管理部210は、受信装置100で同時に実行可能なアプリの数に上限が設けられている場合であって、外部起動実行部220によって指定されたアプリを起動した場合にはアプリの数が前記上限を超えることになってしまう場合には、上記のような所定の優先度にしたがって、既に稼働していたアプリケーションプログラムを終了させる制御を行う。
【0059】
受信装置100において同時に実行可能なアプリの数が例えば1に限られている場合には、アプリケーション稼働管理部210は、次のような制御を行う。放送マネージドアプリから放送独立型アプリに遷移する際には、アプリケーション稼働管理部210は、放送マネージドアプリを終了させてから放送独立型アプリを起動する制御を行う。また、放送独立型アプリから放送マネージドアプリに遷移する際には、アプリケーション稼働管理部210は、放送独立型アプリを終了させてから放送マネージドアプリを起動する制御を行う。
つまり、放送マネージドアプリから放送独立型アプリへの遷移を行う際に、前記上限が1である場合には、アプリケーション稼働管理部210は、遷移元の放送マネージドアプリを終了させてから、遷移先の放送独立型アプリを起動する制御を行う。また、放送独立型アプリから放送マネージドアプリへの遷移を行う際に、前記上限が1である場合には、アプリケーション稼働管理部210は、遷移元の放送独立型アプリを終了させてから、遷移先の放送マネージドアプリを起動する制御を行う。
つまり、同時に1つのアプリしか動作できないアプリケーションエンジンの場合、且つ、外部起動によるアプリ(遷移先の、放送マネージドアプリまたは放送独立型アプリ)の起動の要求を受信し、起動するアプリのURI可否判定を行った結果、実行可能であると判断した場合には、アプリケーション稼働管理部210は、動作中であったアプリ(遷移元のアプリ)を終了させる。
【0060】
図3は、放送マネージドアプリと放送独立型アプリとの間の遷移の方法の例を示す概略図である。図示するように、放送マネージドアプリと放送独立型アプリとは、相互に遷移することが可能である。ここでは、放送信号に基づいて放送マネージドアプリが起動された後、ユーザーの操作等によって放送独立型アプリに遷移し、さらに、放送独立型アプリから放送マネージドアプリに遷移するというシナリオに沿って、その方法を説明する。
【0061】
まず
図3の(1)に示すように、放送信号に基づいて、放送マネージドアプリが起動される。
【0062】
次に
図3の(2)に示すように、放送独立型アプリが起動される。例えば、ユーザーが受信装置100と連携する連携端末装置(不図示)を操作することにより、その連携端末装置が、放送独立型アプリの起動を要求する。ここで、その連携端末装置から指定されるパラメーターの例として、選局先の放送サービスを示す識別情報は「NULL」であり、Appid(アプリ識別情報)は「0x1234」(16進表記)である。選局が「NULL」であることは、放送独立型アプリが特定の放送サービスに従属するものではないことに対応している。なお、選局先の放送サービスを示す識別情報が「NULL」であることは、受信装置100がそれ以前に放送サービス(編成チャンネル)を選局していた場合には、受信装置100は選局済みであった編成チャンネルの選局状態を解除することを意味する。ただし、この「NULL」は一例であり、他の予め指定された値を上記の「NULL」の代わりに用いてもよい。「NULL」に代わる値は、例えば運用ルール等で規定してよい。また、「NULL」に代わる値は、1種類に限らず、複数の予め指定された値等であってもよい。つまり、特定の放送サービスに従属するものではないことを示す特殊な値を、選局先の放送サービスを指定する値として用いることができる。つまり、外部起動実行部220は、指定された放送サービスが予め定められた値(1つまたは複数の予め指定された値。例えば、「NULL」。)である場合には、放送サービスの選局状態を解除するよう選局部5を制御するようにしてよい。また、Appidの「0x1234」は、当該放送独立型アプリに付与された識別情報である。これにより、アプリケーション稼働管理部210は、該当する放送独立型アプリのコードをアプリケーション記憶部201から読み出し、アプリケーション実行部200において実行させる。起動された放送独立型アプリは、アプリケーション実行部200において実行される。この放送独立型アプリは、放送リソースにアクセスすることはできない。しかしながら、この放送独立型アプリは、通信機能部240を介して外部と通信することができる。つまり、例えば、放送独立型アプリは、インターネット経由で提供される映像コンテンツをコンテンツ提供サーバーから受信し、提示部4の機能によって当該受信装置100の画面に表示し、またスピーカー等から音声を出力することができる。その他、放送独立型アプリは、許可されるリソースにアクセスしたり、各種処理を実行したりすることができる。
【0063】
なお、ここでは、ユーザーが連携端末装置を操作することによって放送独立型アプリを起動する例を説明したが、その他にも、テレビリモコン装置からのリモコン信号に基づいて放送独立型アプリを起動したり、前記の放送マネージドアプリから呼び出すことによって放送独立型アプリを起動したりしてもよい。
【0064】
また、選局先の放送サービスの識別情報としては、original_network_id、transport_stream_id、service_idの3種類の識別子の組を、アプリ識別情報としては、アプリケーションのロケーションを示すAITのURLや、アプリケーションの提供者が付与するappId自身、あるいは、アプリケーションの提供者を識別するorgIdとappIdの組などを用いて表現しても構わない。
【0065】
次に
図3の(3)に示すように、放送独立型アプリから放送マネージドアプリに遷移することが可能である。ここでは、稼働中の放送独立型アプリからの要求に基づいて放送マネージドアプリに遷移する例を説明する。放送独立型アプリは、要求生成部222に、ハイブリッドキャストコネクトの機能を実行することを要求する。具体的には、放送独立型アプリは、放送サービスを特定する情報と、アプリ(放送マネージドアプリ)を特定する情報とを指定して、そのアプリを呼び出すことを、要求生成部222に要求する。すると、要求生成部222は、放送独立型アプリから受け取った情報(放送サービスおよびアプリを識別する情報)を用いて、外部起動実行部220に、放送マネージドアプリの呼び出しを要求する。ここで、アプリの呼び出しのために指定されるパラメーターの例は、次の通りである。即ち、選局は「0x9abc」であり、Appid(アプリ識別情報)は「0x5678」である。選局「0x9abc」は、放送サービスを識別する情報である。
また、Appid「0x5678」は、上記放送サービスに従属する放送マネージドアプリに付与された識別情報である。
【0066】
要求を受け付けた外部起動実行部220は、指定された選局の情報と、指定されたアプリ識別情報との、整合性(正当性)を確認する。この整合性の確認は、例えば、外部起動実行部220が、通信ネットワークを介して外部の可否判定サーバー装置に問い合わせることによって行える。両者が整合しない場合には、外部起動実行部220は、この要求をエラーとして扱う。両者が整合する場合には、外部起動実行部220は、選局部5に、選局「0x9abc」で識別される放送サービスを選局するよう指示する。これにより、受信部1は、当該放送サービスを受信する。また、外部起動実行部220は、アプリケーション稼働管理部210に、「0x5678」で識別されるアプリ(放送マネージドアプリ)を起動(あるいは、活性化)するよう指示する。このように、外部起動実行部220は、要求生成部222から要求を受けた場合にも、放送マネージドアプリを正しく安全に稼働状態とすることができる。
【0067】
なお、外部起動実行部220が、指定された放送サービスの識別情報とアプリケーションプログラムの識別情報との間の整合性を、例えば外部のサーバー装置に問い合わせることによって確認することにより、安全な場合にのみ、指定されたアプリが起動されるように制御することができる。つまり、受信装置100の安全性を確保できる。
【0068】
つまり、要求生成部222は、連携端末装置に代わって、外部起動実行部220に、放送マネージドアプリの呼び出しを要求する。この要求生成部222の機能により、受信装置100の内部を起点として、受信装置100内で稼働する放送マネージドアプリを呼び出すことが可能となる。
【0069】
なお、外部起動の仕組みにおいて、連携端末装置側から選局指示を行う場合には、連携端末装置側でstartAITControlledAppToHostDevice()関数(パラメーターとして、mode=”tune”)を実行する。本実施形態では、要求生成部222が、この関数を実行する、あるいはそれと同等の機能を実行する。
【0070】
また、放送マネージドアプリがどのアプリまたはどの種別のアプリから起動されたのかを把握可能とするために、次のようにしてもよい。ここでの「種別」は、放送マネージドアプリ、放送外マネージドアプリ、放送独立型アプリ、一般アプリといった種別に加えて、連携端末装置側のアプリからの起動であることを表す情報である場合もある。呼び出し元となるアプリ(連携端末装置側のアプリや、放送独立型アプリ)が、自身のアプリ識別情報やアプリ種別の情報をパラメーターとして放送マネージドアプリの起動命令に付加する。その起動命令が発行されたときには、外部起動実行部220は、パラメーターが付加された起動命令をアプリケーション稼働管理部210に引継ぐ。そして、アプリケーション稼働管理部210は、パラメーターを付加した状態で、放送マネージドアプリを起動するようにしても構わない。
【0071】
上記動作は、つまり、次の通りである。外部起動実行部220は、アプリケーションプログラム(放送マネージドアプリ)を起動するための要求を受ける際に、要求元識別情報または要求元種別情報の少なくともいずれかの情報をパラメーターとして受け取る。要求元識別情報は、放送マネージドアプリの起動を要求する要求元のアプリケーションプログラムを個別に識別するための識別情報である。要求元種別情報は、放送マネージドアプリの起動を要求する要求元のアプリケーションプログラムの種別を表す。要求元種別情報は、当該受信装置100で稼働する放送独立型アプリケーションプログラムであるか連携端末装置で稼働するアプリケーションプログラムであるかを少なくとも区別する情報である。外部起動実行部220は、指定されたアプリを起動するようアプリケーション稼働管理部210を制御する際に、上記のパラメーターをアプリケーション稼働管理部210に渡す。そして、アプリケーション稼働管理部210は、外部起動実行部220から渡されたパラメーターを、起動対象であるアプリ(放送マネージドアプリ)に渡す。このしくみにより、起動された側のアプリは、受け取ったパラメーターの値に基づき、自己の起動を要求した要求元の、要求元識別情報あるいは要求元種別情報の少なくともいずれかを取得できる。つまり、起動された側のアプリは、パラメーターとして受け取った要求元識別情報あるいは要求元種別情報の少なくともいずれかに依存した処理を行うことができる。
【0072】
次に、本実施形態による受信装置100の応用例を説明する。
【0073】
図4は、受信装置100を利用して実現されるコンテンツ提示システムの稼働例を示す概略図である。同図において、(A)は受信装置100上で放送マネージドアプリが稼働している状態であり、(B)は受信装置100上で放送独立型アプリが稼働している状態である。既に説明したように、これらの両状態のそれぞれから、相互に他方の状態に遷移可能である。
【0074】
図4において、(A)の状態では、受信装置100は放送信号を受信し、その放送信号から放送リソースを抽出する。放送リソースは、映像や音声等のデータである。放送リソースとして取得された映像や音声を、受信装置100の提示部4は、提示することができる。また、(A)に示す放送マネージドアプリは、放送リソースにアクセスすることもできる。また、(A)の放送マネージドアプリは、放送されたコンテンツである映像や音声とともに、別の映像(画像)や音声を提示部4に提示させることもできる。また、(B)に示す放送独立型アプリは、インターネット等を介した通信によって受信する映像および音声のコンテンツのデータを復号し、映像および音声として、提示部4に提示させることができる。この放送独立型アプリは、例えば、ネット配信の映像コンテンツを再生・提示するためのアプリである。
【0075】
状態(A)から(B)に遷移するときには、例えばユーザーがテレビリモコンや連携端末装置を操作することにより、放送独立型アプリを起動する。前述の通りこの放送独立型アプリは通信ネットワークで配信される映像コンテンツを再生することが主な機能であり、特定の放送サービス(テレビのチャンネル)には紐付かない。
【0076】
逆に、状態(B)から(A)に遷移するときには、サービスの構成として、特定の放送サービスに従属する放送マネージドアプリに遷移する場合がある。本実施形態の受信装置100は、そのような、放送独立型アプリから特定の放送サービスの放送マネージドアプリへの遷移を可能とする。つまり、本実施形態は、放送独立型アプリから放送マネージドアプリ(特定の放送サービス)への引き戻しを可能とする。そのための具体的方法の一つとして、ハイブリッドキャストにおける外部起動の手法を利用する。この手法は、例えば受信装置100と連携する連携端末装置から、特定のアプリの識別情報と、特定の放送サービスの識別情報とをセットにして、それらの識別情報を受信装置100に伝えるものである。本実施形態では、前述の要求生成部222が受信装置100の内部に存在し、要求生成部222が、連携端末装置になり代わって放送マネージドアプリの起動要求を生成する。そして、放送独立型アプリが、この要求生成部222に対して、特定の放送サービスが選択され、特定の放送マネージドアプリが起動されるように要求生成を要請することも可能である。
【0077】
以上のように、本実施形態の受信装置100によると、図示する(A)から(B)へ、あるいは(B)から(A)へのスムーズな遷移が可能となる。つまり、本実施形態を用いることにより、放送とネット配信との間のスムーズな切り替えが実現できる。
以上、説明したように、本実施形態によると、放送サービスと、放送独立型アプリ(例えば、通信ネットワークによって配信されるコンテンツの再生のアプリ)との間での、双方向のスムーズな遷移が可能となる。特に、従来においては放送マネージドアプリ以外のアプリから放送マネージドアプリへの遷移ができなかったが、本実施形態ではそのような遷移が可能となる。つまり、テレビ受像機を用いて、例えば放送番組とネット配信アプリとを切り替えて視聴する場合にも、一旦ホーム画面からネット配信アプリを立ち上げる必要があるなどといった不便が解消される。ユーザーにとっては、放送マネージドアプリ以外のアプリが、より一層使いやすくなる。
【0078】
[第2実施形態]
次に、本発明の第2実施形態について説明する。なお、前実施形態において既に説明した事項については以下において説明を省略する場合がある。ここでは、本実施形態に特有の事項を中心に説明する。また、第1実施形態と同様の機能を有する機能ブロックについては、第1実施形態と同じ符号を用いて参照するとともに、詳細な説明を省略する。
【0079】
まず、本実施形態が必要とされる背景から説明する。放送独立型アプリは、受信装置が表示するメニュー画面からの操作によって起動されたり、リモコン装置の操作によって起動されたり、無線LAN等を介して連携する連携端末装置でのユーザーの操作によって起動されたりする。同一の受信装置内のアプリケーション実行環境において、放送マネージドアプリと放送独立型アプリの両方が実行可能である場合、アプリの種別に応じて、アプリの振る舞いを適切に制御できることが求められる。文献「IPTVFJ STD-0010 放送通信連携システム仕様 2.1版」(2016年3月7日,一般社団法人IPTVフォーラム
発行)、および文献「IPTVFJ STD-0013 ハイブリッドキャスト運用規定 2.6版」(2017年11月1日,一般社団法人IPTVフォーラム 発行)においては、放送マネージドアプリの起動は、放送からの起動のみに限定されていた。このため、受信装置は、アプリの起動方法を把握することによってアプリの種別を判定することができていた。しかしながら、その後、これらの規格文書が改訂されたことにより、状況が変化した。即ち、文献「IPTVFJ STD-0010 放送通信連携システム仕様 2.2版」(2018年9月21日,一般社団法人IPTVフォーラム 発行)、および文献「IPTVFJ STD-0013 ハイブリッドキャスト運用規定 2.7版」(2018年9月21日,一般社団法人IPTVフォーラム 発行)においては、放送からだけではなく、連携端末装置からも放送マネージドアプリを起動することが可能となった。つまり、連携端末装置からは、放送マネージドアプリも、その他のアプリも、起動され得ることとなった。これにより、アプリの起動方法(起動手段)に基づいてアプリ種別を判定することが不可能となった。したがって、従来の技術では、ハイブリッドキャストにおいて、受信装置が、アプリの起動方法によってアプリ種別を把握し、そのアプリ種別に応じた適切なアプリの振る舞いの制御を行うことが困難となった。加えて、放送マネージドアプリからはreplaceApplication関数の実行により指定したアプリへの遷移または起動が可能であるが、複数の種別のアプリが同一の受信装置で実行される環境において、アプリの種別に関わらず同一の関数を利用する場合においても、遷移または起動対象となるアプリの種別を判定することが不可能である。
【0080】
複数の種別のアプリの実行を管理するためには、受信装置は、実行させようとするアプリの種別を正確に把握する必要がある。本実施形態では、受信装置の中の管理機能が、アプリの起動方法に依らずに、AIT(アプリケーション情報テーブル)内の情報に基づいてその種別を判定する。
【0081】
図5は、本実施形態による受信装置の概略機能構成を示すブロック図である。図示するように、受信装置300(「受信機」とも呼ばれる)は、受信部1と、復調部2と、復号部3と、提示部4と、選局部5と、アプリケーション実行部200と、アプリケーション記憶部201と、外部起動実行部220と、端末連携部221と、通信機能部240と、アプリケーション稼働管理部410と、AIT管理部420と、受信機ロンチャー部430と、リソースアクセス制御部411とを含んで構成される。
【0082】
上記の構成を有する受信装置300は、ハイブリッドキャストに対応した機能を持つ。
受信部1と、復調部2と、復号部3と、提示部4と、選局部5と、アプリケーション実行部200と、アプリケーション記憶部201と、外部起動実行部220と、端末連携部221と、通信機能部240とについては、既に第1実施形態で説明した通りである。
【0083】
外部起動実行部220は、外部の端末装置(後述する端末装置310)から受信した外部起動命令に基づき、外部の可否判定サーバー装置(後述する可否判定サーバー装置330)への問い合わせを行い、アプリの起動可否を制御する。具体的には、外部起動実行部220は、放送サービスの識別情報(選局情報)と、起動しようとするアプリのAITのURLとを、上記の外部起動命令から抽出する。そして、外部起動実行部220は、その放送サービスの識別情報およびAITのURLを含んだ問合せを、可否判定サーバー装置に送信する。外部起動実行部220は、可否判定サーバー装置から判定結果を受信する。
受信した判定結果がOKである場合には、外部起動実行部220は、そのAITのURLを、AIT管理部420に渡す。受信した判定結果がNGである場合(即ち、アプリ起動不可)には、外部起動実行部220は、そのAITのURLを破棄する。なお、上記のAITのURLは、アプリをユニークに識別する情報である。つまり、外部起動実行部220は、指定された放送サービスの識別情報とアプリケーションプログラムの識別情報との間の整合性を、外部のサーバー装置に問い合わせることによって確認している。つまり、放送サービスとアプリケーションプログラムの整合性が担保される安全な場合にのみ、指定されたアプリが起動されるように制御することができる。つまり、受信装置300の安全性を確保できる。
【0084】
アプリケーション稼働管理部410は、第1実施形態におけるアプリケーション稼働管理部210と同等の機能を有するものであり、アプリの起動および終了等を制御する。アプリケーション稼働管理部410は、さらに、次の機能を有する。アプリの起動時には、アプリケーション稼働管理部410は、AIT管理部420から渡されるアプリ本体のURLに基づき、外部のサービスサーバー装置(後述するサービスサーバー装置340)からアプリ本体のコードを取得する。アプリケーション稼働管理部410は、取得したアプリ本体をアプリケーション実行部200にロードする。この際、アプリケーション稼働管理部410が、アプリ本体をアプリケーション記憶部201にあわせて書き込むようにしてもよい。アプリを終了させる際には、アプリケーション稼働管理部410は、アプリケーション実行部200に終了を指示する。なお。アプリケーション稼働管理部410は、内部にリソースアクセス制御部411を備える。
【0085】
リソースアクセス制御部411は、アプリケーション実行部200において実行中のアプリが、拡張APIを呼び出して放送リソースや受信装置リソースにアクセスしようとする際に、アプリ種別に基づいてアクセス制御を行う。アプリ種別は、AIT管理部420から渡されるものである。なお、アプリ種別ごとに、どのリソースへのアクセスが許されるか許されないかが、予め定められる。
【0086】
AIT管理部420(「アプリケーション情報テーブル管理部」とも呼ばれる。)は、外部起動実行部220や受信機ロンチャー部430からAITのURLを受け取り、そのURLに基づいてAITを取得し、アプリの種別を判定するとともに、アプリ本体のURLをアプリケーション稼働管理部410に渡す。これにより、アプリケーション稼働管理部410は、アプリを起動できる。また、AIT管理部420は、判定結果であるアプリの種別の情報を、アプリケーション稼働管理部410内のリソースアクセス制御部411に渡す。これにより、リソースアクセス制御部411は、アプリの種別に応じて、アプリのリソース(放送リソースや受信機リソース等)へのアクセス可否を制御できる。
【0087】
具体的には、AIT管理部420は、渡されるURLに基づいて、外部のサービスサーバー装置(後述するサービスサーバー装置340)からAITを取得する。また、AIT管理部420は、内部にパージング(parsing)機能を備え、取得したAITをパーズすることにより、そのアプリの種別を判定する。アプリの種別を判定するためのより詳細な方法については、後述する。また、AIT管理部420は、アプリの起動方法とアプリ種別が整合しているか否かを確認する。その詳細についても後述する。
【0088】
受信機ロンチャー部430は、ユーザーのボタン等の操作に基づいて放送独立型アプリを起動する機能を有する。具体的には、受信機ロンチャー部430は、リモコン装置のボタンを押下する操作や、受信装置300自身のメニュー画面からの操作に基づいて、放送独立型アプリを起動する。受信機ロンチャー部430は、操作の種別と関連付けられたアプリのAITのURLを、予め記憶している。受信機ロンチャー部430は、起動対象のアプリのAITのURLを、AIT管理部420に渡す。
【0089】
図6は、受信装置300が稼働するシステムの全体的な装置構成を示すブロック図である。図示するように、このシステムは、受信装置300と、端末装置310と、放送送出装置320と、可否判定サーバー装置330と、サービスサーバー装置340とを含んで構成される。なお、図においては各装置1台ずつを示しているが、各装置の台数は任意である。
【0090】
受信装置300は、放送送出装置320から送出される放送信号を受信する。また、受信装置300は、サービスサーバー装置340から、AITや、アプリのコードや、コンテンツデータ等を受信する。また、受信装置300は、可否判定サーバー装置330に対して、アプリの起動可否を問い合わせる。また、受信装置300は、無線LANを介して、端末装置310との間で通信を行う。
【0091】
端末装置310は、サービスサーバー装置340や受信装置300との間で通信を行う。また、端末装置310は、アプリを実行させる。端末装置310は、無線LANを介して、受信装置300と連携動作する連携端末装置である。端末装置310は、例えば、スマートフォンやタブレット端末によって実現される。
【0092】
放送送出装置320は、放送信号を送出する。放送信号は、空中や、金属ケーブルや、光ファイバーケーブルにより伝送され、受信装置300によって受信される。
【0093】
可否判定サーバー装置330は、受信装置300におけるアプリ(放送マネージドアプリおよび放送独立型アプリ)の起動の可否を判定する。可否判定サーバー装置330は、受信装置300からの問い合わせに対応して、アプリの起動の可否を判定し、判定結果を受信装置300に返す。可否判定サーバー装置330と受信装置300との間の通信は、インターネットを介して行われる。
【0094】
サービスサーバー装置340は、アプリ(放送マネージドアプリおよび放送独立型アプリ)のAITや、アプリ本体(アプリのコード)や、アプリが利用するコンテンツ等を、受信装置300や端末装置310に提供する。サービスサーバー装置340から受信装置300や端末装置310への配信は、インターネットを介した通信により行われる。
【0095】
次に、AITに基づいてアプリ種別を判定するための具体的な方法を説明する。
図7および
図8は、第1のアプリ種別判定方法に関連するものである。
図9および
図10は、第2のアプリ種別判定方法に関連するものである。そして、
図11および
図12は、第3のアプリ種別判定方法に関連するものである。
【0096】
図7および
図8は、アプリ種別を判定する第1の方法で用いるデータ(AIT内のisdb:ServiceDiscovery要素)を示す概略図である。これらの図では、参照のための行番号を付している。
図7は、このデータの第1行目から第24行目までを示す。
図8は、このデータの第25行目から第48行目までを示す。なお、図示する例では、AITは、XML(Extensible Markup Language、拡張可能なマークアップ言語)で記述されている。しかし、AITの記述形式は、XMLには限らず、他の形態のデータであってもよい。
【0097】
図7および
図8に示すAITを用いる場合、AIT管理部420は、例えば、第13行目に記述されているisdb:orgIdの値を用いてアプリ種別を判定する。このorgIdは、アプリを提供する組織(事業者)を識別するための識別子である。つまり、orgIdの値を組織に割り当てる際に、放送マネージドアプリを提供する組織には予め定めた所定の範囲内の値を割り当て、放送独立型アプリを提供する組織には予め定めた他の範囲内の値を割り当てる。その一例として、放送マネージドアプリを提供する組織には1以上且127以下の値を付与し(0は、特別な値としてリザーブされている)、放送独立型アプリを提供する組織には126以上且つ255以下の値を付与する。これは、8ビット符号なし2進数として表現される整数の、最上位ビットが0の場合(放送マネージドアプリを提供する組織)と、最上位ビットが1の場合(放送独立型アプリを提供する組織)とに、それぞれ、相当する。この例の場合には、AIT管理部420は、orgIdの値(2進数表現)の最上位ビットを参照することにより、そのアプリが放送マネージドアプリであるか放送独立型アプリであるかを判定することができる。また、他の例として、放送マネージドアプリを提供する組織には1以上且つ32767以下の値を付与し(0は、特別な値としてリザーブされている)、放送独立型アプリを提供する組織には32768以上且つ65535以下の値を付与する。これは、16ビット符号なし2進数として表現される整数の、最上位ビットが0の場合(放送マネージドアプリを提供する組織)と、最上位ビットが1の場合(放送独立型アプリを提供する組織)とに、それぞれ、相当する。なお、ここで示したorgIdの値の付与のしかたは、例に過ぎず、他の付与のしかたをしてもよい。
【0098】
図9および
図10は、アプリ種別を判定する第2の方法で用いるデータ(AIT内のisdb:ServiceDiscovery要素)を示す概略図である。これらの図では、参照のための行番号を付している。
図9は、このデータの第1行目から第25行目までを示す。
図10は、このデータの第26行目から第49行目までを示す。ここでもAITはXMLで記述されているが、AITの形式は、XMLには限定されず、任意である。
【0099】
図9および
図10に示すAITを用いる場合、AIT管理部420は、AIT内においてアプリの種別を示す識別子を参照することにより、アプリの種別を判定する。具体例として、AIT管理部420は、このAIT(
図9)の第19行目に記述されているisdb:AppTypeの値を参照する。このisdb:AppType要素は、isdb:type要素の配下に存在している。従来の規格(IPTVFJ STD-0013,ハイブリッドキャスト運用規定2.8版,2019年5月14日改定,一般社団法人IPTVフォーラム)によるAITでは、このようなアプリの種別を示す識別子は設けられていない。しかし、本実施形態では、AIT内にisdb:AppType要素を置くようにして、AIT管理部420がアプリ種別を判別できるようにしている。なお、一例として、isdb:AppTypeの値が0のときにはそのアプリの種別は放送マネージドアプリであり、isdb:AppTypeの値が1のときにはそのアプリの種別は放送独立型アプリであると判定できるようにする。なお、ここに示した要素の名称および値は例に過ぎず、他の要素名や他の値を用いるようにしてもよい。その場合も、AIT管理部420は、AIT内における、アプリ種別を表すアプリ種別識別子を参照することによって、アプリの種別を判定する。
【0100】
図11および
図12は、アプリ種別を判定する第3の方法で用いるデータ(AIT内のAplicationDescriptor要素)のシンタックスを示す概略図である。これらの図では、参照のための行番号を付している。
図11は、このデータの第1行目から第11行目までを示す。
図12は、このデータの第12行目から第24行目までを示す。
【0101】
第3の方法では、AIT管理部420は、AIT内のサービス境界フラグ(service bound flag)を参照することにより、アプリ種別を判定する。
図12の第17行目に記載されている要素serviceBoundが、参照されるサービス境界フラグである。図示するように、この要素serviceBoundは、ブーレアン型であり、デフォルト値はtrue(1)である。このサービス境界フラグの値が0(false)のときには、AIT管理部420は、アプリ種別が放送独立型アプリであると判定する。また、サービス境界フラグの値が1(true)のときには、AIT管理部420は、アプリ種別が放送マネージドアプリであると判定する。
なお、サービス境界フラグを、「サービス境界情報」、あるいは「サービスバウンド情報」等と呼んでもよい。
【0102】
以上、アプリの種別を判定するための3つの方法を説明した。なお、AIT管理部420が、これらの3つの方法のうちのいずれか1つの方法のみを用いてアプリの種別を判定するようにしてもよいし、これらの3つの方法のうちの複数の方法を実装するものであってもよい。AIT管理部420が複数の方法を実装する場合には、適宜、それらの方法を使い分ける。
【0103】
AIT管理部420は、次の6通りの起動指示を受ける。即ち、AIT管理部420は、1)復号部3からデータ放送に関連する放送マネージドアプリの起動指示を受ける、2)外部起動実行部220から放送マネージドアプリの起動指示を受ける(連携端末装置からの起動指示)、3)外部起動実行部220から放送独立型アプリの起動指示を受ける(連携端末装置からの起動指示)、4)受信機ロンチャー部430から放送独立型アプリの起動指示を受ける、5)アプリケーション実行部200で実行中の放送マネージドアプリからreplaceApplication関数の実行により放送マネージドアプリの起動指示を受ける、あるいは、6)アプリケーション実行部200で実行中の放送マネージドアプリからreplaceApplication関数の実行により放送独立型アプリの起動指示を受ける。AIT管理部420は、これらの起動指示に基づいて取得したAITに基づいて、アプリの種別を判定する。
【0104】
上記の起動指示の方法のうち、2)と3)の連携端末装置からの外部起動、および、5)と6)の放送マネージドアプリからのreplaceApplication関数の実行による起動に関しては、アプリの種別が異なるにも関わらず同じ起動方法が用いられる。そのため、アプリの起動方法によってアプリ種別を判定するのではなく、AITを参照することによってアプリ種別を判定する。これにより、AIT管理部420は、確実且つ正確にアプリ種別の判定を行える。
【0105】
AIT管理部420は、また、アプリの起動方法とアプリの種別とが整合しているか否かを確認する。具体的には、AIT管理部420は、復号部3からデータ放送に関連する起動指示を受けた場合には、起動するアプリが放送マネージドアプリであることを確認する。データ放送からの起動指示に関するアプリが放送マネージドアプリではない場合には、エラーとして検知する。また、AIT管理部420は、受信機ロンチャー部430からアプリの起動指示を受けた場合には、起動するアプリの種別が放送独立型アプリであることを確認する。受信機ロンチャー部430からの起動指示に関するアプリが放送独立型アプリではない場合には、エラーとして検知する。
【0106】
なお、連携端末からのアプリの起動指示、および、放送マネージドアプリからのアプリの起動指示には、放送マネージドアプリの起動の場合と放送独立型アプリの起動の場合とがある。即ち、いずれの場合にも、起動方法とアプリ種別とは整合していると、AIT管理部420は判定する。
【0107】
AIT管理部420が、アプリの起動方法(データ放送からの起動指示、あるいは受信機ロンチャー部430からの起動指示)とアプリ種別との間の不整合を検知した場合には、アプリケーション稼働管理部410に対して、エラーを通知する。これにより、アプリケーション稼働管理部410は、エラーによりアプリを起動できないことを把握する。このような場合には、アプリケーション稼働管理部410は、そのアプリの起動を抑止するようにする。
【0108】
リソースアクセス制御部411は、AIT管理部420によるアプリ種別の判定結果を受け取る。また、リソースアクセス制御部411は、アプリケーション実行部200で実行中のアプリがAPI(放送リソースや受信装置リソースへのアクセスのための拡張API)を呼び出した場合、受け取っているアプリ種別の情報に基づいて、アクセス制御を行う。
【0109】
そのために、例えば、リソースアクセス制御部411は、アプリ種別ごとに、呼び出し可能なAPIのリストを予め記憶しておく。即ち、リソースアクセス制御部411は、放送マネージドアプリがアクセス可能なAPIのリストと、放送独立型アプリがアクセス可能なAPIのリストとを、それぞれ、記憶しておく。そして、実行中のアプリがAPIを呼び出そうとしたときには、その呼び出しは必ずリソースアクセス制御部411による制御を経由して行われるようにしておく。そして、リソースアクセス制御部411は、APIが呼び出されたときに、当該アプリ(呼び出しを行っているアプリ)の種別を把握し、その種別に応じて前記のAPIリストを参照する。これにより、リソースアクセス制御部411は、API呼び出しが、正当な呼び出しであるか違反であるかを判定する。アクセスが許可されるべきものである場合には、リソースアクセス制御部411は、そのAPI呼び出しをそのまま実行させる。アクセスが許されないものである場合には、リソースアクセス制御部411は、そのAPI呼び出しを中止し、呼び出し側のアプリに対してエラーを返す。このように、リソースアクセス制御部411は、AITに基づいて判定されたアプリ種別と、アクセスされるリソースとが整合するように、制御を行う。
【0110】
リソースアクセス制御の一例として、放送リソースへのアクセスのためのAPIの呼び出しは、放送マネージドアプリには許されるが、放送独立型アプリには許されない。
【0111】
本実施形態についてまとめると、次の通りである。
【0112】
受信装置300は、アプリケーション稼働管理部410と、AIT管理部420とを含む。アプリケーション稼働管理部410は、アプリケーション実行部200で実行されるアプリケーションプログラムの稼働を管理する。AIT管理部420は、アプリケーション実行部200で実行させるアプリケーションプログラムの起動命令を受信した際に、当該アプリケーションプログラム用のアプリケーション情報テーブル(AIT)に基づいてアプリケーションプログラムの種別(例えば、放送マネージドアプリ、放送独立型アプリ)を判定し、判定結果である種別をアプリケーション稼働管理部410に通知する。
【0113】
AIT管理部420は、アプリケーション情報テーブル内の、当該アプリケーションプログラムを提供する組織を識別する情報(例えば、前述のorgID)に基づいて、前記種別を判定してよい。
【0114】
AIT管理部420は、前記アプリケーション情報テーブル内の、当該アプリケーションプログラムの種別を識別する情報(例えば、前述のappType)に基づいて、前記種別を判定してよい。
【0115】
AIT管理部420は、前記アプリケーション情報テーブル内のサービスバウンド情報(例えば、前述のserviceBound)に基づいて、前記種別を判定してよい。
【0116】
AIT管理部420は、前記アプリケーションプログラムの起動方法(例えば、放送からの起動であるか、ロンチャーからの起動であるか、連携端末からの起動であるか等)と前記種別とが整合しているか否かを判定し、整合している場合には当該アプリケーションプログラムの起動を許可し、整合していない場合には当該アプリケーションプログラムの起動を中止させる。なお、AIT管理部420が、アプリケーションプログラムの起動方法と種別との整合性の判定を行わないようにしてもよい。
【0117】
リソースアクセス制御部411は、AIT管理部420が判定した結果である種別を受け取り、その種別に応じて、アプリケーション実行部200において実行中のアプリケーションプログラムが要求したリソースへのアクセスを許可するか否かを制御する。なお、リソースアクセス制御部411が、アプリケーションプログラムの種別に応じたアクセス制御を行わないようにしてもよい。
【0118】
以上、説明したように、本実施形態によれば、同一のアプリケーション実行環境において複数の種別のアプリ(ハイブリッドキャストアプリ)を動作させる際に、AITに基づいて種別を判定することが可能となる。つまり、アプリの起動方法に依らずに、確実かつ正確にアプリの種別を判定できる。また、判定された種別に基づき、アプリからのリソース(放送リソースや受信装置リソース)へのアクセスを制御できるようになる。
【0119】
[第3実施形態]
次に、本発明の第3実施形態について説明する。なお、前実施形態までにおいて既に説明した事項については以下において説明を省略する場合がある。ここでは、本実施形態に特有の事項を中心に説明する。また、第1実施形態や第2実施形態と同様の機能を有する機能ブロックについては、それらの実施形態と同じ符号を用いて参照するとともに、詳細な説明を省略する。
【0120】
図13は、本実施形態による受信装置の概略機能構成を示すブロック図である。図示するように、受信装置500(「受信機」とも呼ばれる)は、受信部1と、復調部2と、復号部3と、提示部4と、選局部5と、アプリケーション実行部200と、アプリケーション記憶部201と、アプリケーション稼働管理部410と、AIT管理部420と、外部起動実行部220と、端末連携部221と、要求生成部222と、受信機ロンチャー部430と、通信機能部240とを含んで構成される。また、アプリケーション稼働管理部410は、リソースアクセス制御部411を含む。
【0121】
これらの機能部のうち、受信部1と、復調部2と、復号部3と、提示部4と、選局部5と、アプリケーション実行部200と、アプリケーション記憶部201と、外部起動実行部220と、端末連携部221と、要求生成部222と、通信機能部240とについては、第1実施形態で説明した通りである。また、アプリケーション稼働管理部410と、AIT管理部420と、受信機ロンチャー部430とについては、第2実施形態で説明した通りである。さらに、リソースアクセス制御部411についても、第2実施形態で説明した通りである。
【0122】
つまり、受信装置500は、ハイブリッドキャスト対応のテレビ受像機として機能し、放送信号を受信してその映像やコンテンツを提示する。また、受信装置500は、アプリを稼働させる環境を持つ。受信装置500は、放送マネージドアプリや放送独立型アプリなど、複数種別のアプリを管理し、実行させる。また、受信装置500は、起動方法に基づいてアプリの種別を判定するのではなく、AIT内の情報を解析することによってアプリの種別を判定する。また、受信装置500は、そのように判定されたアプリの種別に基づいて、アプリの挙動を(具体的には、リソースへのアクセスの可否等を)制御する。
【0123】
[第4実施形態]
次に、本発明の第4実施形態について説明する。なお、前実施形態までにおいて既に説明した事項については以下において説明を省略する場合がある。ここでは、本実施形態に特有の事項を中心に説明する。また、第1実施形態から第3実施形態までのいずれかと同様の機能を有する機能ブロックについては、それらの実施形態と同じ符号を用いて参照するとともに、詳細な説明を省略する。
【0124】
放送独立型アプリケーションは、放送リソースがない状態(放送が選局されていない状態)で起動することができるアプリケーションである。地域の異なる系列局等において、あるいは異なる状況において、同一のサービス(番組等)が放送される場合には、受信機を設置している場所や状況に関わらず、全ての受信機に対して同一のアプリケーションが提供される。一方、受信機にとっては、設置されている場所や状況によって、受信可能な放送サービス(メディアおよびチャンネル)が異なる。そのため、放送独立型アプリケーションから放送サービスを選局させようとした場合、確実に受信可能な放送サービス(メディアおよびチャンネル)を選局することができないという課題がある。本実施形態は、このような課題を解決しようとするものである。
【0125】
図14は、本実施形態による受信装置の概略機能構成を示すブロック図である。図示するように、受信装置700(「受信機」とも呼ばれる)は、受信部1と、復調部2と、復号部3と、提示部4と、選局部705と、アプリケーション実行部800と、アプリケーション記憶部201と、外部起動実行部220と、端末連携部221と、通信機能部240と、アプリケーション稼働管理部410と、AIT管理部420と、受信機ロンチャー部430と、リソースアクセス制御部411とを含んで構成される。リソースアクセス制御部411は、アプリケーション稼働管理部410内に含まれる。
【0126】
上記の構成を有する受信装置700は、ハイブリッドキャストに対応した機能を持つ。受信部1と、復調部2と、復号部3と、提示部4と、アプリケーション記憶部201と、外部起動実行部220と、端末連携部221と、通信機能部240と、アプリケーション稼働管理部410と、AIT管理部420と、受信機ロンチャー部430と、リソースアクセス制御部411とについては、既に第2実施形態で説明した通りである。本実施形態に特有の機能(選局部705およびアプリケーション実行部800)は、次に説明する通りである。
【0127】
選局部705は、前述の選局部5と同様に、受信部1が受信する放送信号の放送サービス(チャンネル)を選局する機能を持つ。選局部705は、また、選局可能な放送サービスの情報(メディアおよびチャンネルの情報)を内部に保持する機能を持つ。この選局可能なメディアおよびチャンネルの情報には、後述するAPIを介してアクセス可能である。
【0128】
アプリケーション実行部800は、アプリケーションプログラム(放送マネージドアプリケーションや放送独立型アプリケーション)を実行させる実行環境である。具体的には、アプリケーション実行部800は、放送リソースや受信機リソースにアクセスするための拡張APIを備えたHTML5ブラウザーである。アプリケーション実行部800は、拡張APIの一つとして、上記の選局部705が保持するメディアおよびチャンネルの情報を取得するためのAPIを有する。
【0129】
アプリケーションプログラムから選局するために受信装置700が持つ機能は、次の通りである。選局部705は、放送独立型アプリケーションプログラムまたは放送マネージドアプリケーションプログラムによる選局指示にしたがって前記放送サービスを選局する。アプリケーション稼働管理部410は、放送独立型アプリケーションプログラムが選局指示を行った場合には、適切なタイミングで、当該前記放送独立型アプリケーションプログラムを終了させる。
【0130】
選局部705は、選局可能なメディアの情報を保持する。また、選局部705は、前記メディアに対応付けて選局可能なチャンネルの情報を保持する。アプリケーション実行部800で動作する放送独立型アプリケーションプログラムは、所定のアプリケーションプログラムインターフェースを介して、選局部705が保持する上記の選局可能なメディアの情報を取得することができる。また、放送独立型アプリケーションプログラムは、所定のアプリケーションプログラムインターフェースを介して、選局部705が保持する、すべての選局可能なチャンネルの情報、または特定のメディアの選局可能なチャンネルの情報、を取得することができる。放送独立型アプリケーションプログラムは、取得した選局可能なチャンネルの情報を用いて、アプリケーションプログラムインターフェースを介して、指定したチャンネルの放送サービスを選局するよう、選局部705に指示できる。選局部705は、この指示にしたがって、特定の放送サービスを選局する。
【0131】
図15は、本実施形態による動作手順の例を示すフローチャートである。このフローチャートは、受信装置700上で稼働する放送独立型アプリケーションから放送を選局する際の動作手順を示す。この動作の前提として、全国の複数の地域に系列局(放送局)を持つキー局(放送局)が、放送独立型アプリケーションによるサービスを展開している。つまり、単一の放送独立型アプリケーションが、地域に依らずに使用される。一方、地域ごとの放送局に依って、放送サービス(メディアおよびチャンネル)は異なり得る。本実施形態の受信装置700は、その設置されている場所(地域)に関わらず、放送独立型アプリケーションから、適切に所望の放送サービス(メディアおよびチャンネル)を選局することが必要とされる。なお、ここで放送独立型アプリケーションが選局の対象とする放送サービスは、地上デジタルの放送サービスである。
【0132】
なお、放送サービスの識別子とは、original_network_id(オリジナルネットワークID)、transport_stream_id(トランスポートストリームID)、service_id(サービスID)の3つの識別子の組み合わせである。また、getAvailableMedia関数およびgetChannelInformation関数のそれぞれは、拡張APIを介した要求を行うための関数である。getAvailableMedia関数は、選局可能なメディアの情報を取得するための関数である。getChannelInformation関数は、選局可能なチャンネルの情報を取得するための関数である。以下、フローチャートに沿って手順を説明する。
【0133】
ステップS701において、放送独立型アプリケーションの動作として、アプリケーション実行部800は、当該放送独立型アプリケーションがサービスの対象とする系列放送局のすべての放送サービスの識別子のリスト(リストAと呼ぶ)を取得する。このすべての放送サービスの識別子のリストは、例えば、当該放送独立型アプリケーションが持つコード(データ領域)の一部として記録されていてもよい。
【0134】
次に、ステップS702において、放送独立型アプリケーションの動作として、アプリケーション実行部800は、選局可能なメディアのリスト(リストBと呼ぶ)を取得する。この選局可能なメディアのリストは、getAvailableMedia関数を呼び出すことによって取得可能である。
【0135】
次に、ステップS703において、放送独立型アプリケーションの動作として、アプリケーション実行部800は、ステップS702で取得したリストBに、「TD」が入っているか否かを判定する。この「TD」は、地上デジタル放送を表すものである。地上デジタル放送は、国内の所定の地域においてのみ受信され得る放送である。リストBに「TD」が入っている場合(ステップS703:YES)には、ステップS704に進む。リストBに「TD」が入っていない場合(ステップS703:NO)には、対象の放送サービスを受信できないため、ステップS707に進む。
【0136】
次に、ステップS704において、放送独立型アプリケーションの動作として、アプリケーション実行部800は、選局可能なチャンネ一覧(リストCと呼ぶ)を取得する。この選局可能なチャンネルのリストは、getChannelInformation関数を呼び出すことによって取得可能である。選局可能なチャンネルのリストは、受信装置700が設置されている場所(地域)に依存する。
【0137】
次に、ステップS705において、放送独立型アプリケーションの動作として、アプリケーション実行部800は、選局可能なチャンネルのリスト(リストC)内に所望の放送サービスの識別子が含まれるか否かを判定する。ここで、所望の放送サービスの識別子とは、リストAに含まれる放送サービスの識別子の中のいずれか一つである。選局可能なチャンネルのリストの中に所望の放送サービスの識別子が含まれている場合(S705:YES)には、ステップS706に進む。選局可能なチャンネルのリストの中に所望の放送サービスの識別子が含まれていない場合(S705:NO)には、対象の放送サービスを受信できないため、ステップS707に進む。
【0138】
次に、ステップS706において、放送独立型アプリケーションの動作として、アプリケーション実行部800は、リストCに含まれているとステップS705で判定したサービスの識別子を用いて、放送サービスを選局する。具体的には、放送独立型アプリケーション内で放送サービスの識別子を指定してtuneTo関数を呼び出すことによって、アプリケーション実行部800は、選局部705に対して、該当する放送サービスを選局させる。選局部705は、指示された放送サービスの識別子にしたがって、選局を行う。これにより、所望の放送サービスが選局される。つまり、受信装置700は、その放送サービスを受信する。つまり、受信装置700が設置されている地域がどこであっても、その地域に応じて、放送独立型アプリケーションからの選局が行える。本ステップの終了後、放送独立型アプリケーションは、本フローチャート全体の処理を終了する。
【0139】
なお、ステップS707に進んだ場合(S703またはS705から)には、放送独立型アプリケーションの動作として、アプリケーション実行部800は、選局が不可能である旨のメッセージを画面等に表示する。本ステップの終了後、放送独立型アプリケーションは、本フローチャート全体の処理を終了する。
【0140】
以上説明したように、本実施形態によると、受信装置700がどの地域に設置されていても、放送独立型アプリケーションから、その地域に応じた適切な放送サービスを選局することが可能となる。また、例えばその地域に該当する放送サービスがない場合など、受信装置700が選局できない場合には、その旨のメッセージを表示することができる。
【0141】
なお、上述した各実施形態における受信装置の少なくとも一部の機能をコンピューターで実現することができる。その場合、この機能を実現するためのプログラムをコンピューター読み取り可能な記録媒体に記録して、この記録媒体に記録されたプログラムをコンピューターシステムに読み込ませ、実行することによって実現しても良い。なお、ここでいう「コンピューターシステム」とは、OSや周辺機器等のハードウェアを含むものとする。また、「コンピューター読み取り可能な記録媒体」とは、フレキシブルディスク、光磁気ディスク、ROM、CD-ROM、DVD-ROM、USBメモリー等の可搬媒体、コンピューターシステムに内蔵されるハードディスク等の記憶装置のことをいう。さらに「コンピューター読み取り可能な記録媒体」とは、インターネット等のネットワークや電話回線等の通信回線を介してプログラムを送信する場合の通信線のように、一時的に、動的にプログラムを保持するもの、その場合のサーバーやクライアントとなるコンピューターシステム内部の揮発性メモリーのように、一定時間プログラムを保持しているものも含んでも良い。また上記プログラムは、前述した機能の一部を実現するためのものであっても良く、さらに前述した機能をコンピューターシステムにすでに記録されているプログラムとの組み合わせで実現できるものであっても良い。
【0142】
以上、この発明の実施形態について図面を参照して詳述してきたが、具体的な構成はこの実施形態に限られるものではなく、変形例を実施してもよく、この発明の要旨を逸脱しない範囲の設計を有する構成としてもよい。
【産業上の利用可能性】
【0143】
本発明は、例えば、放送と通信とを連携するサービスや、そういったサービスを実現するための機器等に利用することができる。但し、本発明の利用範囲はここに例示したものには限られない。
【符号の説明】
【0144】
1 受信部
2 復調部
3 復号部
4 提示部
5 選局部
100 受信装置(受信機)
200 アプリケーション実行部
201 アプリケーション記憶部
210 アプリケーション稼働管理部
211 放送マネージドアプリ管理部
212 放送外マネージドアプリ管理部
213 放送独立型アプリ管理部
214 一般アプリ管理部
220 外部起動実行部
221 端末連携部
222 要求生成部
240 通信機能部
300 受信装置(受信機)
310 端末装置
320 放送送出装置
330 可否判定サーバー装置
340 サービスサーバー装置
410 アプリケーション稼働管理部
411 リソースアクセス制御部
420 AIT管理部(アプリケーション情報テーブル管理部)
430 受信機ロンチャー部
500 受信装置(受信機)
700 受信装置(受信機)
705 選局部
800 アプリケーション実行部