Outdated version of the documentation. Find the latest one here.

QGISの旧バージョンとの互換性

プラグインメニュー

新しいメニュー(ラスタ、:guilabel: ベクタ、:guilabel: データベース`や `ウェブ)のいずれかにプラグインのメニュー項目を配置する場合は、`` initGui()``と``unload()``関数のコードを変更する必要があります。これらの新しいメニューのみQGIS2.0で利用可能なので、最初のステップは、実行中のQGISのバージョンがすべての必要な機能を持っていることをチェックすることです。新しいメニューが利用可能な場合、我々はこのメニューにプラグインを配置します。そうでなければ我々は、古い`プラグ`メニューを使用します。ここで`ラスタ`メニューの例を次に示します。:

def initGui(self):
  # create action that will start plugin configuration
  self.action = QAction(QIcon(":/plugins/testplug/icon.png"), "Test plugin", self.iface.mainWindow())
  self.action.setWhatsThis("Configuration for test plugin")
  self.action.setStatusTip("This is status tip")
  QObject.connect(self.action, SIGNAL("triggered()"), self.run)

  # check if Raster menu available
  if hasattr(self.iface, "addPluginToRasterMenu"):
    # Raster menu and toolbar available
    self.iface.addRasterToolBarIcon(self.action)
    self.iface.addPluginToRasterMenu("&Test plugins", self.action)
  else:
    # there is no Raster menu, place plugin under Plugins menu as usual
    self.iface.addToolBarIcon(self.action)
    self.iface.addPluginToMenu("&Test plugins", self.action)

  # connect to signal renderComplete which is emitted when canvas rendering is done
  QObject.connect(self.iface.mapCanvas(), SIGNAL("renderComplete(QPainter *)"), self.renderTest)

def unload(self):
  # check if Raster menu available and remove our buttons from appropriate
  # menu and toolbar
  if hasattr(self.iface, "addPluginToRasterMenu"):
    self.iface.removePluginRasterMenu("&Test plugins",self.action)
    self.iface.removeRasterToolBarIcon(self.action)
  else:
    self.iface.removePluginMenu("&Test plugins",self.action)
    self.iface.removeToolBarIcon(self.action)

  # disconnect from signal of the canvas
  QObject.disconnect(self.iface.mapCanvas(), SIGNAL("renderComplete(QPainter *)"), self.renderTest)